/* ===========================================================================
   Personalizirano - front-end styles
   theme.json provides design tokens. This file is for what theme.json can't.
   =========================================================================== */

:root {
  --pzr-radius-sm: 4px;
  --pzr-radius-md: 8px;
  --pzr-radius-tile: 18px;
  --pzr-radius-lg: 24px;
  --pzr-radius-pill: 999px;
  --pzr-shadow-glow: 0 0 0 3px rgba(255, 214, 10, 0.35);
  --pzr-easing: cubic-bezier(.2,.7,.2,1);

  /* Hero - only used by Hero pattern */
  --pzr-hero-bg: #0B0712;
  --pzr-pink: #FF4FA3;
  --pzr-violet: #7B2CFF;
}

html { scroll-behavior: smooth; }

body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ===========================================================================
   Block style variations
   =========================================================================== */

/* Eyebrow heading - mono, uppercase, leading dash */
.wp-block-heading.is-style-eyebrow,
.is-style-eyebrow {
  font-family: var(--wp--preset--font-family--mono) !important;
  font-size: 0.6875rem !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--wp--preset--color--ink);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.wp-block-heading.is-style-eyebrow::before,
.is-style-eyebrow::before {
  content: "";
  width: 22px;
  height: 1px;
  background: currentColor;
}

/* Outline text - display headings with stroked transparent fill */
.wp-block-heading.is-style-outline {
  -webkit-text-stroke: 1.5px var(--wp--preset--color--ink);
  color: transparent;
}

/* Card group - paper bg, warm border, rounded */
.wp-block-group.is-style-card {
  background: var(--wp--preset--color--paper);
  border: 1px solid var(--wp--preset--color--line);
  border-radius: var(--pzr-radius-lg);
  padding: clamp(1.5rem, 3vw, 2.25rem);
  display: flex;
  flex-direction: column;
  height: 100%;
  box-sizing: border-box;
}
.wp-block-group.is-style-card > .wp-block-buttons:last-child {
  margin-top: auto;
}

/* Ink card - inverse */
.wp-block-group.is-style-card-ink {
  background: var(--wp--preset--color--ink);
  color: var(--wp--preset--color--base);
  border-radius: var(--pzr-radius-lg);
  padding: clamp(1.5rem, 3vw, 2.25rem);
  display: flex;
  flex-direction: column;
  height: 100%;
  box-sizing: border-box;
}
.wp-block-group.is-style-card-ink > .wp-block-buttons:last-child {
  margin-top: auto;
}
.wp-block-group.is-style-card-ink :where(h1,h2,h3,h4,h5,h6,p,a) { color: inherit; }

/* Button styles */
.wp-block-button.is-style-ink > .wp-block-button__link {
  background: var(--wp--preset--color--ink) !important;
  color: var(--wp--preset--color--base) !important;
}
.wp-block-button.is-style-ink > .wp-block-button__link:hover {
  background: #1a1a1a !important;
}

.wp-block-button.is-style-ghost > .wp-block-button__link {
  background: transparent !important;
  color: var(--wp--preset--color--ink) !important;
  border: 1px solid var(--wp--preset--color--ink);
}
.wp-block-button.is-style-ghost > .wp-block-button__link:hover {
  background: var(--wp--preset--color--ink) !important;
  color: var(--wp--preset--color--base) !important;
}

.wp-block-button.is-style-blue > .wp-block-button__link {
  background: var(--wp--preset--color--ink-blue) !important;
  color: #fff !important;
}

.wp-block-button.is-style-hero-cta > .wp-block-button__link {
  background: linear-gradient(100deg, #FF4FA3 0%, #C44FFF 55%, #8B2FFF 100%) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 24px rgba(180, 50, 255, 0.45), 0 1px 8px rgba(255, 79, 163, 0.35) !important;
  transition: filter 180ms, box-shadow 180ms !important;
}
.wp-block-button.is-style-hero-cta > .wp-block-button__link:hover {
  filter: brightness(1.12) !important;
  box-shadow: 0 6px 32px rgba(180, 50, 255, 0.6), 0 2px 12px rgba(255, 79, 163, 0.45) !important;
}

/* Pill - small mono badge */
.is-style-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--wp--preset--color--line);
  border-radius: var(--pzr-radius-pill);
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--wp--preset--color--paper);
}

/* ===========================================================================
   Form fields
   =========================================================================== */

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
textarea,
select {
  font-family: var(--wp--preset--font-family--sans);
  font-size: 0.9375rem;
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--wp--preset--color--line);
  border-radius: var(--pzr-radius-md);
  background: var(--wp--preset--color--paper);
  color: var(--wp--preset--color--ink);
  outline: none;
  transition: border-color 120ms, box-shadow 120ms;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--wp--preset--color--ink);
  box-shadow: var(--pzr-shadow-glow);
}

/* Focus states - accessible */
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: 2px solid var(--wp--preset--color--ink-blue);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ===========================================================================
   Hero - neon-dark variant. Used by Hero pattern via .pzr-hero wrapper class.
   =========================================================================== */

.pzr-hero {
  position: relative;
  background: var(--pzr-hero-bg);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.pzr-hero :where(h1,h2,h3,h4,h5,h6,p,a) { color: inherit; }

.pzr-hero::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,79,163,0.18), transparent 55%),
    linear-gradient(180deg, rgba(123,44,255,0.05), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.pzr-hero__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: screen;
}
.pzr-hero__glow--pink   { width: 760px; height: 760px; top: -160px; right: -120px; background: #FF4FA3; opacity: 0.55; }
.pzr-hero__glow--violet { width: 620px; height: 620px; left: -160px; top: 20%;     background: #7B2CFF; opacity: 0.5; }
.pzr-hero__glow--gold   { width: 520px; height: 320px; left: 30%;   bottom: -80px; background: #FFD66B; opacity: 0.28; filter: blur(140px); }

.pzr-hero > *:not(.pzr-hero__glow) { position: relative; z-index: 2; }

/* Shared chip/label - used as a corner badge on gallery tiles etc. */
.pzr-pill-label {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  padding: 4px 10px;
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.625rem;
  letter-spacing: 0.14em;
  font-weight: 700;
  border-radius: var(--pzr-radius-pill);
  text-transform: uppercase;
  background: rgba(14,14,14,0.7);
  color: #fff;
}
.pzr-pill-label--accent {
  background: var(--wp--preset--color--yellow);
  color: var(--wp--preset--color--ink);
}

/* ===========================================================================
   Before/After slider - hero
   =========================================================================== */

.pzr-ba-slider {
  position: relative;
  overflow: hidden;
  border-radius: var(--pzr-radius-tile);
  aspect-ratio: 3 / 4;
  background: rgba(255,255,255,0.04);
  box-shadow: 0 20px 60px rgba(0,0,0,0.45);
  cursor: ew-resize;
  user-select: none;
  -webkit-user-select: none;
}

.pzr-ba-slider__before,
.pzr-ba-slider__after {
  position: absolute;
  inset: 0;
}
.pzr-ba-slider__before img,
.pzr-ba-slider__after img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
/* JS sets clip-path; default shows 50/50 */
.pzr-ba-slider__after {
  clip-path: inset(0 0 0 50%);
}

.pzr-ba-slider__chip {
  position: absolute;
  top: 0.75rem;
  padding: 4px 10px;
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.625rem;
  letter-spacing: 0.14em;
  font-weight: 700;
  border-radius: var(--pzr-radius-pill);
  text-transform: uppercase;
  background: rgba(14,14,14,0.7);
  color: #fff;
  pointer-events: none;
}
.pzr-ba-slider__before .pzr-ba-slider__chip { left: 0.75rem; }
.pzr-ba-slider__after  .pzr-ba-slider__chip {
  right: 0.75rem;
  background: var(--wp--preset--color--yellow);
  color: var(--wp--preset--color--ink);
}

.pzr-ba-slider__handle {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 2px;
  background: rgba(255,255,255,0.7);
  transform: translateX(-50%);
  pointer-events: none;
  transition: left 0ms; /* instant - JS controls it */
}
.pzr-ba-slider__handle-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 44px; height: 44px;
  background: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #1a1a1a;
  font-size: 1rem;
  font-weight: 700;
  box-shadow: 0 2px 16px rgba(0,0,0,0.25);
  letter-spacing: -0.05em;
}

.pzr-ba-slider__range {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  opacity: 0;
  cursor: ew-resize;
  z-index: 10;
  margin: 0;
  -webkit-appearance: none;
}

.pzr-ba-slider__hint {
  position: absolute;
  bottom: 0.875rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 12px;
  background: rgba(14,14,14,0.7);
  color: #fff;
  border-radius: var(--pzr-radius-pill);
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.625rem;
  letter-spacing: 0.14em;
  font-weight: 700;
  text-transform: uppercase;
  pointer-events: none;
  white-space: nowrap;
  transition: opacity 400ms;
}

/* ===========================================================================
   Marquee - infinite scrolling ticker
   =========================================================================== */

.pzr-marquee {
  overflow: hidden;
  background: var(--wp--preset--color--yellow);
  border-block: 1px solid var(--wp--preset--color--ink);
  padding-block: 0.875rem;
}
.pzr-marquee__track {
  display: inline-flex;
  gap: 3rem;
  white-space: nowrap;
  animation: pzr-marquee-scroll 28s linear infinite;
  font-family: var(--wp--preset--font-family--mono);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.8125rem;
  font-weight: 600;
}
@keyframes pzr-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .pzr-marquee__track { animation: none; }
}

/* ===========================================================================
   Examples - gallery tiles + songs
   =========================================================================== */

.pzr-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
@media (max-width: 880px) {
  .pzr-gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .pzr-gallery { grid-template-columns: 1fr; }
}

.pzr-tile {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pzr-tile__media {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: var(--pzr-radius-tile);
  overflow: hidden;
  background: #1A1A18;
}
.pzr-tile__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Before chip is positioned at the bottom; the default .pzr-pill-label sits top-left. */
.pzr-tile__chip--before {
  top: auto;
  bottom: 0.75rem;
  background: rgba(14,14,14,0.85);
}
.pzr-tile__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.pzr-tile__title {
  font-size: 0.9375rem;
  font-weight: 600;
}
.pzr-tile__num {
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  color: rgba(255,247,240,0.5);
}

.pzr-songs {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pzr-song {
  display: grid;
  grid-template-columns: 40px minmax(140px, 1fr) minmax(0, 3fr) 56px;
  align-items: center;
  gap: 1.25rem;
  padding: 0.5rem 0;
}
.pzr-song__play {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: var(--wp--preset--color--yellow);
  color: var(--wp--preset--color--ink);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform 120ms;
}
.pzr-song__play:hover { transform: scale(1.05); }
.pzr-song__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.pzr-song__title {
  font-size: 0.9375rem;
  font-weight: 600;
}
.pzr-song__sub {
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  color: rgba(255,247,240,0.55);
  text-transform: uppercase;
}
.pzr-song__wave {
  display: flex;
  align-items: center;
  gap: 2px;
  height: 36px;
  overflow: hidden;
}
.pzr-song__wave span {
  display: block;
  width: 3px;
  background: rgba(255,247,240,0.55);
  border-radius: 2px;
  flex-shrink: 0;
}
.pzr-song__time {
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.75rem;
  color: rgba(255,247,240,0.6);
  text-align: right;
}

@media (max-width: 640px) {
  .pzr-song {
    grid-template-columns: 40px 1fr 56px;
    grid-template-areas:
      "play meta time"
      "wave wave wave";
    gap: 0.75rem 1rem;
  }
  .pzr-song__play { grid-area: play; }
  .pzr-song__meta { grid-area: meta; }
  .pzr-song__time { grid-area: time; }
  .pzr-song__wave { grid-area: wave; }
}

/* ===========================================================================
   Testimonials - editorial list
   =========================================================================== */

.pzr-reviews {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--wp--preset--color--line);
}
.pzr-review {
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr) minmax(180px, 220px);
  align-items: start;
  gap: 2.5rem;
  padding: 2rem 0;
  border-bottom: 1px solid var(--wp--preset--color--line);
}
.pzr-review__num {
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  color: var(--wp--preset--color--muted);
  padding-top: 0.5rem;
}
.pzr-review__quote {
  margin: 0;
  padding: 0;
  border: 0;
  quotes: none;
  color: var(--wp--preset--color--ink);
}
.pzr-review__quote p {
  margin: 0;
  font-family: var(--wp--preset--font-family--display);
  font-size: clamp(1.125rem, 1.6vw, 1.625rem);
  line-height: 1.35;
  letter-spacing: -0.005em;
  font-weight: 600;
}
.pzr-review__byline {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.375rem;
  text-align: right;
}
.pzr-review__stars {
  color: var(--wp--preset--color--yellow);
  font-size: 0.875rem;
  letter-spacing: 0.05em;
}
.pzr-review__name {
  font-weight: 700;
  font-size: 0.9375rem;
}
.pzr-review__service {
  font-family: var(--wp--preset--font-family--mono);
  font-size: 0.625rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wp--preset--color--muted);
}

@media (max-width: 720px) {
  .pzr-review {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 1.5rem 0;
  }
  .pzr-review__byline {
    align-items: flex-start;
    text-align: left;
  }
}

/* ===========================================================================
   Footer
   =========================================================================== */

footer.wp-block-group :where(li, li a, p) {
  color: #E0DDD7;
}
footer.wp-block-group :where(li a):hover {
  color: #fff;
}

/* ===========================================================================
   Sticky nav
   =========================================================================== */

.pzr-nav {
  position: sticky;
  top: 0;
  z-index: 30;
  background: rgba(250, 247, 240, 0.85);
  border-bottom: 1px solid var(--wp--preset--color--line);
}

/* Desktop only: backdrop blur for the sticky nav over the hero.
   On mobile the nav opens a full-screen overlay; backdrop-filter would create
   a containing block that traps position:fixed children — keep it off. */
@media (min-width: 783px) {
  .pzr-nav {
    background: rgba(250, 247, 240, 0.85);
    backdrop-filter: blur(8px);
  }
}

/* Row alignment: site-title left, nav links beside it, icons + CTA flush right.
   space-between on the parent treats `margin: auto` as the dominant rule, so a
   single auto-margin on the navigation block partitions the row cleanly. */
.pzr-nav > .wp-block-group {
  align-items: center;
  gap: 1rem;
}

@media (min-width: 783px) {
  .pzr-nav .wp-block-navigation {
    margin-right: auto;
    margin-left: 2rem;
  }
  .pzr-nav .wp-block-woocommerce-customer-account,
  .pzr-nav .wp-block-woocommerce-mini-cart-block,
  .pzr-nav .wp-block-woocommerce-mini-cart {
    margin-left: 0;
  }
}

@media (max-width: 782px) {
  /* Hide the desktop CTA — mobile users tap a real "Order now" deeper in the page */
  .pzr-nav .wp-block-buttons {
    display: none;
  }

  /* Cluster hamburger + account + cart on the right edge */
  .pzr-nav > .wp-block-group {
    gap: 0.5rem;
  }
  .pzr-nav .wp-block-navigation {
    margin-left: auto;
  }
  .pzr-nav .wp-block-woocommerce-customer-account a,
  .pzr-nav .wp-block-woocommerce-mini-cart-block button {
    padding: 0.375rem;
  }

  /* === Mobile nav overlay ===
     WP ships sane defaults (position:fixed; inset:0; display:block when open).
     We layer flex centering, our own padding, and an absolute-positioned close
     button on top. Selectors are specific enough (.pzr-nav .is-menu-open ...)
     to beat WP without !important — only the items font-size needs !important
     because WP renders inline style="font-size:0.875rem" on the <a>. */

  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 4rem 1.5rem 2rem;
    background: var(--wp--preset--color--base, #FAF7F0);
    z-index: 9999;
  }
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open *,
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open *::before,
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open *::after {
    box-sizing: border-box;
  }

  /* The WP wrappers (__responsive-close, __responsive-dialog, content) are
     block elements by default; turn them into transparent flex pass-throughs
     so the column-center alignment cascades all the way to the items. */
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close,
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog,
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    flex: 1 1 auto;
    width: 100%;
    margin: 0;
    padding: 0;
  }

  /* The <ul> ships with inline justify-content:right from the parent nav block;
     reset it to a vertical, evenly-spaced stack. */
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.25rem;
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    width: 100%;
    text-align: center;
  }
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
    display: block;
    padding: 0.875rem 0;
    text-align: center;
    font-size: 1.5rem !important; /* overrides inline style on the <a> */
  }

  /* Close (X) — fixed to viewport so it can't be offset by the modal's padding
     or the position:relative __responsive-dialog wrapper. */
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
    position: fixed;
    top: 1rem;
    right: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: 1px solid rgba(14, 14, 14, 0.15);
    border-radius: 999px;
    background: transparent;
    color: var(--wp--preset--color--ink, #0E0E0E);
    cursor: pointer;
  }
  .pzr-nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
    width: 1.25rem;
    height: 1.25rem;
    fill: currentColor;
  }

  /* Lock background scroll while the overlay is open */
  html.has-modal-open,
  html.has-modal-open body {
    overflow: hidden;
    height: 100%;
    touch-action: none;
  }

  /* Before/after slider — cap height on mobile so it doesn't dominate */
  .pzr-ba-slider {
    aspect-ratio: unset;
    height: clamp(260px, 55vw, 380px);
  }
}

/* ===========================================================================
   Mobile polish
   =========================================================================== */

@media (max-width: 600px) {
  .pzr-hero {
    padding-top: 1.75rem !important;
    padding-bottom: 3rem !important;
  }
  .pzr-hero > .wp-block-group:first-of-type {
    margin-bottom: 1.5rem !important;
  }
  .pzr-hero .wp-block-columns:last-of-type {
    margin-top: 2.5rem !important;
  }

  .wp-block-group.is-style-card,
  .wp-block-group.is-style-card-ink {
    height: auto;
  }

  footer.wp-block-group .wp-block-column + .wp-block-column {
    margin-top: 0;
  }
  footer.wp-block-group .wp-block-columns {
    gap: 2rem !important;
  }

  .pzr-promo-bar {
    justify-content: center;
    gap: 0.5rem;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .pzr-promo-bar p {
    text-align: center;
    font-size: 0.7rem;
  }
  /* Mobile: message is enough — CTA below it duplicates the sticky header's intent */
  .pzr-promo-bar .wp-block-buttons {
    display: none;
  }
}

/* Desktop promo bar — constrain inner content to the same content width as
   the rest of the site so the text doesn't hug the viewport edge. */
@media (min-width: 783px) {
  .pzr-promo-bar {
    padding-left: clamp(1rem, calc((100% - 1280px) / 2), 8rem) !important;
    padding-right: clamp(1rem, calc((100% - 1280px) / 2), 8rem) !important;
    align-items: center;
  }
}
