  /* =========================================================
     ZEMMA — Premium Booking SaaS landing
     ========================================================= */

  :root {
    --bg: #1A1438;
    --bg-2: #221B45;
    --bg-3: #1F1840;
    --surface: #2A2356;
    --surface-2: #322A60;
    --line: rgba(190, 165, 255, 0.14);
    --line-strong: rgba(190, 165, 255, 0.28);

    --ink: #F8F4FF;
    --ink-soft: #DCD2F3;
    --ink-mute: #9F94BF;
    --ink-faint: #6E608F;

    --violet: #A084FF;
    --violet-2: #C9B0FF;
    --magenta: #E89BFF;
    --pink: #FFB3E6;
    --gold: #F4D88A;

    --grad-text: linear-gradient(110deg, #FFFFFF 0%, #E0CCFF 38%, #E89BFF 78%, #FFB3E6 100%);
    --grad-cta: linear-gradient(135deg, #B591FF 0%, #8A5CFF 50%, #6E3CFF 100%);
    --grad-cta-hover: linear-gradient(135deg, #C5A5FF 0%, #9B6DFF 50%, #7E4CFF 100%);
    --grad-glow: radial-gradient(60% 60% at 50% 50%, rgba(160, 132, 255, 0.55) 0%, rgba(160, 132, 255, 0) 70%);

    --shadow-card: 0 1px 0 rgba(255,255,255,0.04) inset, 0 30px 60px -30px rgba(0,0,0,0.8);
    --shadow-cta: 0 10px 40px -10px rgba(138, 92, 255, 0.6), 0 0 0 1px rgba(255,255,255,0.08) inset;

    --radius: 18px;
    --radius-lg: 26px;
    --radius-xl: 34px;

    --maxw: 1240px;
  }

  *, *::before, *::after { box-sizing: border-box; }
  html {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    width: 100%;
    scroll-behavior: smooth;
  }
  body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: 'Bricolage Grotesque', system-ui, sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    letter-spacing: -0.005em;
    position: relative;
    width: 100%;
    /* Sticky footer pattern — page is at least viewport tall, footer drops to bottom */
    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }
  body > main { flex: 1 0 auto; }
  body > footer { flex-shrink: 0; }
  /* Prevent any element from causing horizontal scroll */
  img, svg, video, iframe { max-width: 100%; height: auto; }
  main, header, section, footer, .container, .hero-grid, .auto-grid { max-width: 100%; }

  body::before {
    content: "";
    position: fixed; inset: 0;
    background:
      radial-gradient(1200px 600px at 80% -10%, rgba(160, 120, 255, 0.22), transparent 60%),
      radial-gradient(900px 500px at -10% 30%, rgba(232, 155, 255, 0.13), transparent 60%),
      radial-gradient(800px 800px at 50% 110%, rgba(140, 90, 255, 0.22), transparent 60%);
    pointer-events: none;
    z-index: 0;
  }
  body::after {
    content: "";
    position: fixed; inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.6 0 0 0 0 0.5 0 0 0 0 0.9 0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
    opacity: 0.04;
    mix-blend-mode: overlay;
    pointer-events: none;
    z-index: 1;
  }

  main, header, footer { position: relative; z-index: 2; }

  a { color: inherit; text-decoration: none; }
  button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

  .container {
    width: 100%;
    max-width: var(--maxw);
    padding: 0 28px;
    margin: 0 auto;
  }

  /* ===== Typography helpers ===== */
  .eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Geist Mono', ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--violet-2);
    padding: 7px 14px;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(160, 132, 255, 0.06), rgba(160, 132, 255, 0.02));
    backdrop-filter: blur(8px);
  }
  .eyebrow::before {
    content: "";
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--magenta);
    box-shadow: 0 0 12px var(--magenta);
  }

  /* Lighter, more readable headers */
  h1, h2, h3, h4 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 500;
    letter-spacing: -0.025em;
    line-height: 1.08;
    margin: 0;
  }

  .display {
    font-size: clamp(48px, 6.6vw, 92px);
    font-weight: 500;
    line-height: 0.98;
    letter-spacing: -0.035em;
  }
  .display .accent {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    background: var(--grad-text);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    letter-spacing: -0.01em;
  }

  .h2 {
    font-size: clamp(34px, 4.6vw, 64px);
    font-weight: 500;
    line-height: 1.03;
    letter-spacing: -0.025em;
  }
  .h2 .accent {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    background: var(--grad-text);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  .lead {
    color: var(--ink-soft);
    font-size: clamp(16px, 1.2vw, 18px);
    line-height: 1.65;
    max-width: 56ch;
    font-weight: 400;
  }

  /* ===== Buttons ===== */
  .btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 22px;
    border-radius: 999px;
    font-weight: 500;
    font-size: 15px;
    letter-spacing: -0.005em;
    transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
    white-space: nowrap;
  }
  .btn-primary {
    background: var(--grad-cta);
    color: #fff;
    box-shadow: var(--shadow-cta);
  }
  .btn-primary {
    position: relative;
    overflow: hidden;
  }
  .btn-primary::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.18) 50%, transparent 70%);
    transform: translateX(-100%);
    transition: transform .8s ease;
    pointer-events: none;
  }
  .btn-primary:hover::after { transform: translateX(100%); }
  .btn-primary:hover {
    background: var(--grad-cta-hover);
    transform: translateY(-1px);
    box-shadow: 0 14px 50px -10px rgba(138, 92, 255, 0.75), 0 0 0 1px rgba(255,255,255,0.12) inset;
  }
  .btn-primary svg { transition: transform .25s ease; }
  .btn-primary:hover svg { transform: translateX(3px); }

  .btn-ghost {
    color: var(--ink);
    border: 1px solid var(--line-strong);
    background: rgba(255,255,255,0.02);
    backdrop-filter: blur(6px);
  }
  .btn-ghost:hover {
    background: rgba(255,255,255,0.05);
    border-color: rgba(168, 132, 255, 0.4);
  }

  /* ===== Header ===== */
  header.site {
    position: sticky;
    top: 0;
    z-index: 50;
    overflow: visible;
    padding-top: env(safe-area-inset-top, 0px);
    backdrop-filter: blur(14px);
    background: rgba(8, 5, 15, 0.6);
    border-bottom: 1px solid var(--line);
  }
  .nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0;
    gap: 24px;
  }
  .logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
  }
  .logo-img {
    height: 38px;
    width: auto;
    display: block;
    filter: drop-shadow(0 4px 16px rgba(160, 132, 255, 0.25));
  }

  .nav-links {
    display: flex;
    align-items: center;
    gap: 4px;
    margin: 0 auto;
  }
  .nav-links a {
    padding: 9px 14px;
    border-radius: 999px;
    color: var(--ink-soft);
    font-size: 14.5px;
    transition: color .2s ease, background .2s ease;
  }
  .nav-links a:hover {
    color: var(--ink);
    background: rgba(255,255,255,0.04);
  }

  .nav-right {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .lang-switch {
    position: relative;
  }
  .lang {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--line-strong);
    background: rgba(255,255,255,0.02);
    font-family: 'Geist Mono', monospace;
    font-size: 12px;
    color: var(--ink-soft);
    cursor: pointer;
    transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
  }
  .lang:hover {
    background: rgba(160, 132, 255, 0.10);
    color: var(--ink);
    border-color: rgba(190, 165, 255, 0.4);
  }
  .lang-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 168px;
    background: rgba(34, 27, 69, 0.96);
    backdrop-filter: blur(18px);
    border: 1px solid var(--line-strong);
    border-radius: 14px;
    padding: 6px;
    box-shadow: 0 20px 60px -20px rgba(0,0,0,0.7);
    display: none;
    z-index: 50;
    animation: langMenuIn 0.22s cubic-bezier(.2,.8,.2,1);
  }
  .lang-switch.open .lang-menu { display: flex; flex-direction: column; gap: 2px; }
  @keyframes langMenuIn {
    from { opacity: 0; transform: translateY(-6px) scale(0.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
  }
  .lang-menu button {
    text-align: left;
    padding: 9px 14px;
    border-radius: 9px;
    font-size: 13.5px;
    color: var(--ink-soft);
    transition: background 0.2s ease, color 0.2s ease;
    font-family: inherit;
  }
  .lang-menu button:hover {
    background: rgba(160, 132, 255, 0.14);
    color: var(--ink);
  }
  .lang-menu button.active {
    background: rgba(160, 132, 255, 0.20);
    color: var(--ink);
  }
  .login {
    color: var(--ink-soft);
    padding: 8px 14px;
    font-size: 14.5px;
  }
  .login:hover { color: var(--ink); }

  .mobile-only { display: none; }

  /* ===== Hamburger menu button (mobile only) ===== */
  .hamburger {
    display: none;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    border: 1px solid var(--line-strong);
    background: rgba(255,255,255,0.04);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    cursor: pointer;
    transition: background .25s ease, border-color .25s ease;
    flex-shrink: 0;
  }
  .hamburger span {
    display: block;
    width: 18px;
    height: 1.8px;
    background: var(--ink);
    border-radius: 2px;
    transition: transform .35s cubic-bezier(.2,.8,.2,1), opacity .25s ease;
    transform-origin: center;
  }
  .hamburger:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(168, 132, 255, 0.4);
  }
  body.menu-open .hamburger span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  body.menu-open .hamburger span:nth-child(2) {
    opacity: 0;
  }
  body.menu-open .hamburger span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  /* ===== Mobile menu overlay ===== */
  .mobile-menu {
    position: fixed;
    inset: 0;
    z-index: 49;
    background: rgba(20, 14, 50, 0.92);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-12px);
    transition: opacity .35s ease, visibility .35s ease, transform .4s cubic-bezier(.2,.8,.2,1);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 24px 40px;
    overscroll-behavior: contain;
  }
  body.menu-open .mobile-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  body.menu-open {
    overflow: hidden;
    touch-action: none;
    overscroll-behavior: contain;
  }
  body.menu-open .mobile-menu {
    touch-action: auto;
    overscroll-behavior: contain;
  }
  .mobile-menu-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
    width: 100%;
    max-width: 360px;
    text-align: center;
  }
  .mobile-nav {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    align-items: center;
  }
  .mobile-nav a {
    display: block;
    width: 100%;
    padding: 16px 22px;
    font-size: 19px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--ink);
    border-radius: 14px;
    transition: background .2s ease, color .2s ease;
    text-align: center;
  }
  .mobile-nav a:hover { background: rgba(160, 132, 255, 0.12); color: var(--violet-2); }
  .mobile-login {
    margin-top: 8px !important;
    color: var(--ink-mute) !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.18em !important;
    font-family: 'Geist Mono', monospace;
  }
  .mobile-cta {
    width: 100%;
    justify-content: center;
    padding: 16px 24px !important;
    font-size: 15px !important;
  }
  .mobile-lang-panel {
    display: none;
    position: relative;
    z-index: 6;
    width: 100%;
    padding: 16px;
    border-radius: 22px;
    border: 1px solid var(--line-strong);
    background: rgba(255,255,255,0.04);
  }
  .mobile-lang-panel > span {
    display: block;
    margin-bottom: 12px;
    font-family: 'Geist Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-mute);
    text-align: center;
  }
  .mobile-lang-dropdown {
    position: relative;
    width: 100%;
  }
  .mobile-lang-trigger {
    width: 100%;
    min-height: 56px;
    padding: 0 18px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background-color: rgba(22, 14, 48, 0.96);
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font: 600 16px/1 'Bricolage Grotesque', system-ui, sans-serif;
    cursor: pointer;
    outline: none;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
  }
  .mobile-lang-trigger svg {
    color: var(--violet-2);
    transition: transform .2s ease;
  }
  .mobile-lang-dropdown.open .mobile-lang-trigger svg {
    transform: rotate(180deg);
  }
  .mobile-lang-trigger:focus-visible {
    border-color: rgba(190, 165, 255, 0.55);
    box-shadow: 0 0 0 4px rgba(160, 132, 255, 0.14);
  }
  .mobile-lang-menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    z-index: 90;
    display: none;
    gap: 4px;
    padding: 6px;
    border-radius: 16px;
    border: 1px solid rgba(190, 165, 255, 0.32);
    background: rgba(31, 24, 64, 0.98);
    box-shadow: 0 24px 60px -26px rgba(0,0,0,0.85);
  }
  .mobile-lang-dropdown.open .mobile-lang-menu {
    display: grid;
  }
  .mobile-lang-menu button {
    min-height: 44px;
    border-radius: 12px;
    color: var(--ink);
    font: 600 15px/1 'Bricolage Grotesque', system-ui, sans-serif;
    text-align: center;
    transition: background .18s ease, color .18s ease;
  }
  .mobile-lang-menu button:hover,
  .mobile-lang-menu button.active {
    background: rgba(160, 132, 255, 0.20);
    color: #fff;
  }

  /* ===== Hero ===== */
  .hero {
    position: relative;
    /* Popunjava cijeli viewport ispod headera (header je sticky ~70px) */
    min-height: calc(100vh - 70px);
    padding: clamp(48px, 6vh, 88px) 0 clamp(56px, 8vh, 110px);
    overflow: hidden;
    display: flex;
    align-items: center;
  }
  .hero > .container { width: 100%; }
  .hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: clamp(32px, 4vw, 60px);
    align-items: center;
  }
  .hero-text { max-width: 640px; }
  .hero-text .display { margin-top: 24px; }
  .hero-text .lead { margin-top: 26px; }
  .hero-ctas { display: flex; align-items: center; gap: 14px; margin-top: 38px; flex-wrap: wrap; }
  .hero-trust {
    margin-top: 18px;
    color: var(--ink-mute);
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .hero-trust svg { color: var(--magenta); width: 14px; height: 14px; }

  .hero-stats {
    margin-top: clamp(28px, 4vh, 52px);
    display: grid;
    grid-template-columns: repeat(3, auto);
    gap: clamp(20px, 3vw, 44px);
    width: fit-content;
  }
  .stat .num {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 36px;
    font-weight: 500;
    letter-spacing: -0.03em;
    background: var(--grad-text);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    line-height: 1;
  }
  .stat .lbl {
    margin-top: 8px;
    font-family: 'Geist Mono', monospace;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-mute);
  }

  /* ===== Phone mockup ===== */
  .phone-stage {
    position: relative;
    height: clamp(540px, 66vh, 650px);
    display: grid;
    place-items: center;
    isolation: isolate;
  }
  .phone-stage::before,
  .phone-stage::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
  }
  .phone-stage::before {
    width: clamp(380px, 39vw, 590px);
    height: clamp(380px, 39vw, 590px);
    border: 1px solid rgba(232, 155, 255, 0.12);
    box-shadow:
      inset 0 0 0 1px rgba(255,255,255,0.035),
      0 0 120px -52px rgba(232, 155, 255, 0.65);
  }
  .phone-stage::after {
    width: clamp(270px, 28vw, 430px);
    height: clamp(270px, 28vw, 430px);
    background:
      radial-gradient(circle at 52% 48%, rgba(232, 155, 255, 0.22), transparent 62%),
      radial-gradient(circle at 42% 45%, rgba(160, 132, 255, 0.28), transparent 64%);
    filter: blur(6px);
    opacity: 0.9;
  }
  .glow-orb {
    position: absolute;
    width: clamp(360px, 38vw, 560px);
    height: clamp(280px, 30vw, 460px);
    border-radius: 50%;
    background:
      radial-gradient(circle at 52% 46%, rgba(232, 155, 255, 0.32), transparent 45%),
      radial-gradient(circle at 30% 65%, rgba(70, 213, 255, 0.16), transparent 52%),
      var(--grad-glow);
    filter: blur(24px);
    z-index: 0;
    animation: pulse 6s ease-in-out infinite;
  }
  @keyframes pulse {
    0%, 100% { transform: scale(1); opacity: 0.85; }
    50% { transform: scale(1.06); opacity: 1; }
  }
  .phone {
    position: relative;
    width: clamp(284px, 24vw, 328px);
    height: clamp(540px, 44vw, 608px);
    border-radius: 48px;
    background:
      linear-gradient(145deg, rgba(255,255,255,0.16), rgba(255,255,255,0.025) 22%, rgba(0,0,0,0.55) 70%),
      linear-gradient(145deg, #21143a 0%, #070511 100%);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.22),
      inset 0 -18px 40px rgba(0,0,0,0.42),
      0 0 0 1px rgba(232, 155, 255, 0.14),
      0 0 0 10px rgba(10, 6, 24, 0.54),
      0 52px 110px -34px rgba(0,0,0,0.88),
      0 0 95px -16px rgba(160, 132, 255, 0.55);
    z-index: 2;
    overflow: hidden;
    transform: rotate(-1.4deg);
    animation: float 8s ease-in-out infinite;
  }
  @keyframes float {
    0%, 100% { transform: rotate(-1.4deg) translateY(0); }
    50% { transform: rotate(-1.4deg) translateY(-12px); }
  }
  .phone::before {
    content: "";
    position: absolute;
    top: 14px; left: 50%;
    transform: translateX(-50%);
    width: 102px; height: 28px;
    border-radius: 999px;
    background: #000;
    z-index: 5;
  }
  .phone::after {
    content: "";
    position: absolute;
    inset: 10px auto 12px 18px;
    width: 34%;
    border-radius: 36px 0 0 36px;
    background: linear-gradient(100deg, rgba(255,255,255,0.16), transparent 68%);
    opacity: 0.22;
    pointer-events: none;
    z-index: 4;
  }
  .phone-screen {
    position: absolute;
    inset: 8px;
    border-radius: 40px;
    background:
      radial-gradient(260px 180px at 50% -8%, rgba(160, 132, 255, 0.34), transparent 72%),
      radial-gradient(220px 150px at 110% 18%, rgba(232, 155, 255, 0.18), transparent 68%),
      linear-gradient(180deg, #1b1032 0%, #10091f 46%, #080512 100%);
    padding: 50px 17px 16px;
    overflow: hidden;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
  }
  .phone-screen .ph-head {
    display: flex; justify-content: space-between; align-items: center;
    color: var(--ink-soft);
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    margin-bottom: 12px;
    padding: 0 4px;
  }
  .ph-brand {
    display: grid;
    grid-template-columns: 40px 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 12px;
    border-radius: 20px;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.035)),
      rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  }
  .ph-logo {
    width: 40px;
    height: 40px;
    border-radius: 15px;
    display: grid;
    place-items: center;
    background: var(--grad-cta);
    box-shadow: 0 14px 28px -16px rgba(232, 155, 255, 0.85);
    font-weight: 700;
    color: #fff;
  }
  .phone-screen .ph-title {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 17px;
    font-weight: 600;
    letter-spacing: -0.02em;
    margin: 0 0 2px;
  }
  .phone-screen .ph-sub {
    font-size: 11px;
    color: var(--ink-mute);
    margin: 0;
  }
  .ph-live {
    position: relative;
    font-family: 'Geist Mono', monospace;
    font-size: 9.5px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #77f2af;
    padding: 6px 8px 6px 18px;
    border-radius: 999px;
    background: rgba(110, 231, 166, 0.08);
    border: 1px solid rgba(110, 231, 166, 0.18);
  }
  .ph-live::before {
    content: "";
    position: absolute;
    left: 8px; top: 50%;
    width: 6px; height: 6px;
    transform: translateY(-50%);
    border-radius: 50%;
    background: #6ee7a6;
    box-shadow: 0 0 12px #6ee7a6;
  }
  .ph-progress {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    margin: 12px 0 10px;
    padding: 5px;
    border-radius: 999px;
    background: rgba(255,255,255,0.055);
    border: 1px solid rgba(255,255,255,0.065);
  }
  .ph-progress span {
    padding: 7px 6px;
    border-radius: 999px;
    text-align: center;
    font-size: 10.5px;
    color: var(--ink-mute);
    font-weight: 600;
  }
  .ph-progress span.active {
    background: rgba(255,255,255,0.12);
    color: var(--ink);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  }
  .ph-service {
    display: flex; align-items: center; gap: 12px;
    padding: 9px 10px;
    border-radius: 17px;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.09), rgba(255,255,255,0.028)),
      rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.075);
    margin-bottom: 8px;
    transition: background .3s ease, border-color .3s ease, transform .3s ease;
  }
  .ph-service:hover { transform: translateY(-1px); background: rgba(255,255,255,0.07); }
  .ph-service.selected {
    border-color: rgba(232, 155, 255, 0.32);
    box-shadow: 0 16px 34px -28px rgba(232, 155, 255, 0.85);
  }
  .ph-service .av {
    width: 34px; height: 34px;
    border-radius: 14px;
    background: linear-gradient(135deg, #c9b0ff, #7C3AED);
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
  }
  .ph-service .av::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.3));
  }
  .ph-service .info { flex: 1; }
  .ph-service .info .nm {
    font-size: 12.5px; font-weight: 600;
    color: var(--ink);
  }
  .ph-service .info .meta {
    font-size: 10.5px; color: var(--ink-mute);
    margin-top: 2px;
  }
  .ph-service .arrow {
    color: var(--ink-mute);
    font-size: 14px;
  }
  .ph-cal {
    margin-top: 12px;
    padding: 11px;
    border-radius: 18px;
    background:
      radial-gradient(180px 70px at 50% 0%, rgba(160,132,255,0.14), transparent 72%),
      rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.075);
  }
  .ph-cal-head {
    display: flex; justify-content: space-between; align-items: center;
    color: var(--ink-soft);
    font-size: 11px;
    margin-bottom: 8px;
  }
  .ph-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    text-align: center;
  }
  .ph-cal-grid .d {
    font-family: 'Geist Mono', monospace;
    font-size: 10px;
    padding: 4px 0;
    border-radius: 6px;
    color: var(--ink-soft);
  }
  .ph-cal-grid .d.head { color: var(--ink-faint); font-size: 9px; }
  .ph-cal-grid .d.active {
    background: var(--grad-cta);
    color: white;
    font-weight: 700;
    box-shadow: 0 8px 18px -10px rgba(232, 155, 255, 0.8);
  }
  .ph-cal-grid .d.dim { color: var(--ink-faint); }
  .ph-slots {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 7px;
    margin-top: 10px;
  }
  .ph-slots span {
    padding: 8px 5px;
    border-radius: 999px;
    text-align: center;
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    color: var(--ink-soft);
    background: rgba(255,255,255,0.055);
    border: 1px solid rgba(255,255,255,0.065);
  }
  .ph-slots span.active {
    background: rgba(160, 132, 255, 0.22);
    border-color: rgba(232, 155, 255, 0.3);
    color: #fff;
  }
  .ph-confirm {
    margin-top: 10px;
    padding: 12px 10px;
    border-radius: 16px;
    background: var(--grad-cta);
    text-align: center;
    font-size: 12.5px;
    font-weight: 700;
    color: white;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.22),
      0 12px 34px -12px rgba(138, 92, 255, 0.74);
  }

  .float-card {
    position: absolute;
    background:
      linear-gradient(135deg, rgba(255,255,255,0.13), rgba(255,255,255,0.035)),
      rgba(16, 9, 34, 0.82);
    backdrop-filter: blur(18px);
    border: 1px solid var(--line-strong);
    border-radius: 18px;
    padding: 12px 16px;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.08),
      0 24px 70px -34px rgba(0,0,0,0.82);
    z-index: 3;
    animation: floatCard 7s ease-in-out infinite;
  }
  .float-card.fc-1 { top: 14%; left: -6%; animation-delay: 0s; }
  .float-card.fc-2 { top: 38%; right: -10%; animation-delay: 1.5s; }
  .float-card.fc-3 { bottom: 16%; left: -10%; animation-delay: 3s; }
  @keyframes floatCard {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
  }
  .float-card .row { display: flex; align-items: center; gap: 10px; }
  .float-card .ic {
    width: 32px; height: 32px; border-radius: 10px;
    background: var(--grad-cta);
    display: grid; place-items: center;
    flex-shrink: 0;
    box-shadow: 0 4px 14px -4px rgba(138, 92, 255, 0.6);
  }
  .float-card .ic svg { width: 15px; height: 15px; color: white; }
  .float-card .label {
    font-family: 'Geist Mono', monospace;
    font-size: 9.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--violet-2);
  }
  .float-card .value {
    font-size: 13.5px;
    font-weight: 500;
    color: var(--ink);
    margin-top: 2px;
    letter-spacing: -0.01em;
  }
  .float-card .delta {
    color: #6EE7A6;
    font-family: 'Geist Mono', monospace;
    font-size: 11px;
    margin-left: 4px;
  }

  /* ===== Section base ===== */
  section {
    padding: clamp(56px, 8vw, 100px) 0;
    position: relative;
  }
  .section-head {
    max-width: 760px;
    margin-bottom: clamp(28px, 3.5vw, 44px);
  }
  .section-head .eyebrow { margin-bottom: 16px; }

  #kako-radi,
  #automatizacija,
  #cijene {
    background: var(--bg);
  }

  /* Premium section skin — Zemma signature background */
  #industrije,
  #features,
  #paneli,
  #recenzije,
  #faq {
    background:
      radial-gradient(780px 420px at 14% 12%, rgba(232, 155, 255, 0.14), transparent 62%),
      radial-gradient(720px 420px at 86% 8%, rgba(160, 132, 255, 0.18), transparent 60%),
      linear-gradient(180deg, #211A46 0%, #17112F 100%);
    overflow: hidden;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.045), inset 0 -1px 0 rgba(255,255,255,0.035);
  }
  #industrije::before,
  #features::before,
  #paneli::before,
  #recenzije::before,
  #faq::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      radial-gradient(900px 460px at 100% 0%, rgba(232, 155, 255, 0.08), transparent 62%),
      radial-gradient(720px 460px at 0% 100%, rgba(160, 132, 255, 0.07), transparent 62%);
    pointer-events: none;
    opacity: 0.9;
  }
  #industrije::after,
  #features::after,
  #paneli::after,
  #recenzije::after,
  #faq::after {
    content: "";
    position: absolute;
    inset: 8% 6% auto;
    height: 52%;
    background-image:
      linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
    background-size: 44px 44px;
    -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, transparent 68%);
    mask-image: radial-gradient(ellipse at center, #000 0%, transparent 68%);
    opacity: 0.5;
    pointer-events: none;
  }
  #industrije > .container,
  #features > .container,
  #paneli > .container,
  #recenzije > .container,
  #faq > .container {
    position: relative;
    z-index: 1;
  }

  #paneli {
    background:
      radial-gradient(780px 420px at 14% 12%, rgba(232, 155, 255, 0.16), transparent 62%),
      radial-gradient(720px 420px at 86% 8%, rgba(160, 132, 255, 0.20), transparent 60%),
      linear-gradient(180deg, #211A46 0%, #17112F 100%);
  }

  /* Section dividers — subtle gradient line */
  section + section::before {
    content: "";
    position: absolute;
    top: 0; left: 50%;
    transform: translateX(-50%);
    width: 60%; height: 1px;
    background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
    opacity: 0.5;
  }

  /* ===== Benefits strip ===== */
  .benefits {
    padding: 36px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(160, 132, 255, 0.03), rgba(160, 132, 255, 0));
  }
  .benefits-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
  }
  .benefit {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--ink-soft);
    font-size: 14.5px;
    letter-spacing: -0.005em;
  }
  .benefit svg {
    width: 18px; height: 18px;
    color: var(--magenta);
  }

  /* ===== Industries ===== */
  .industries-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
  }
  /* When grid wraps to 3 cols, last 2 should center nicely */
  .industry-card {
    position: relative;
    padding: 28px 18px;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.005));
    border: 1px solid var(--line);
    transition: transform .3s ease, border-color .3s ease, background .3s ease, box-shadow .3s ease;
    text-align: center;
    cursor: default;
  }
  .industry-card:hover {
    transform: translateY(-8px) scale(1.02);
    border-color: var(--line-strong);
    background: linear-gradient(180deg, rgba(232, 155, 255, 0.10), rgba(255,255,255,0.02));
    box-shadow: 0 24px 60px -28px rgba(160, 132, 255, 0.55);
  }
  .industry-card:hover .ico {
    transform: scale(1.08) rotate(-4deg);
    background: linear-gradient(135deg, rgba(160, 132, 255, 0.30), rgba(232, 155, 255, 0.16));
    box-shadow: 0 0 0 6px rgba(160, 132, 255, 0.10);
  }
  .industry-card .ico {
    transition: transform .35s cubic-bezier(.2,.8,.2,1), background .35s ease, box-shadow .35s ease;
  }
  .industry-card .ico {
    width: 56px; height: 56px;
    border-radius: 16px;
    margin: 0 auto 18px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, rgba(160, 132, 255, 0.18), rgba(232, 155, 255, 0.08));
    border: 1px solid var(--line-strong);
    color: var(--violet-2);
  }
  .industry-card .ico svg { width: 26px; height: 26px; }
  .industry-card h4 {
    font-size: 17px;
    font-weight: 500;
    letter-spacing: -0.01em;
    margin-bottom: 6px;
  }
  .industry-card p {
    color: var(--ink-mute);
    font-size: 13px;
    margin: 0;
    line-height: 1.5;
  }

  /* ===== Manifest ===== */
  .manifest {
    text-align: center;
    padding: clamp(72px, 9vw, 110px) 0;
  }
  .manifest .h2 { margin-top: 18px; }
  .manifest .lead { margin: 22px auto 0; }

  /* ===== Features ===== */
  .features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }
  .feat-card {
    position: relative;
    padding: 32px 30px 30px;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
    border: 1px solid var(--line);
    overflow: hidden;
    transition: transform .35s ease, border-color .35s ease, background .35s ease;
  }
  .feat-card::before {
    content: "";
    position: absolute;
    top: -1px; left: -1px; right: -1px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(232, 155, 255, 0.5), transparent);
    opacity: 0;
    transition: opacity .35s ease;
  }
  .feat-card:hover {
    transform: translateY(-6px);
    border-color: var(--line-strong);
    background: linear-gradient(180deg, rgba(160, 132, 255, 0.06), rgba(255,255,255,0.02));
    box-shadow: 0 28px 64px -32px rgba(160, 132, 255, 0.5);
  }
  .feat-card:hover::before { opacity: 1; }
  .feat-card .ico { transition: transform .35s cubic-bezier(.2,.8,.2,1); }
  .feat-card:hover .ico { transform: scale(1.1) rotate(-6deg); }
  .feat-card .top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 38px;
  }
  .feat-card .ico {
    width: 44px; height: 44px;
    border-radius: 12px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, rgba(160, 132, 255, 0.2), rgba(232, 155, 255, 0.1));
    border: 1px solid var(--line-strong);
    color: var(--violet-2);
  }
  .feat-card .ico svg { width: 20px; height: 20px; }
  .feat-card .tag {
    font-family: 'Geist Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-mute);
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(0,0,0,0.2);
  }
  .feat-card h3 {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: -0.015em;
    margin-bottom: 12px;
  }
  .feat-card p {
    color: var(--ink-soft);
    font-size: 14.5px;
    line-height: 1.6;
    margin: 0;
  }

  /* ===== How it works (3 clean steps — panel-card style) ===== */
  .steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    position: relative;
  }
  .step-card {
    position: relative;
    padding: 36px 32px 32px;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008));
    border: 1px solid var(--line);
    overflow: hidden;
    transition: transform .35s cubic-bezier(.2,.8,.2,1), border-color .3s ease, background .35s ease, box-shadow .35s ease;
  }
  .step-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(160, 132, 255, 0.08), transparent 40%);
    opacity: 0;
    transition: opacity .35s ease;
    pointer-events: none;
  }
  .step-card:hover {
    transform: translateY(-6px);
    border-color: var(--line-strong);
    box-shadow: 0 26px 60px -28px rgba(160, 132, 255, 0.55);
  }
  .step-card:hover::before { opacity: 1; }
  .step-card .top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 18px;
    position: relative; z-index: 1;
  }
  .step-card .role {
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--violet-2);
  }
  .step-card .dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--magenta);
    box-shadow: 0 0 14px var(--magenta);
  }
  .step-card .num {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    font-size: 64px;
    line-height: 1;
    background: var(--grad-text);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 16px;
    letter-spacing: -0.02em;
    position: relative; z-index: 1;
  }
  .step-card h3 {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: -0.015em;
    margin-bottom: 12px;
    position: relative; z-index: 1;
  }
  .step-card p {
    color: var(--ink-soft);
    font-size: 14.5px;
    line-height: 1.65;
    margin: 0 0 22px;
    position: relative; z-index: 1;
  }
  .step-card .pills {
    display: flex; flex-wrap: wrap; gap: 6px;
    position: relative; z-index: 1;
  }
  .step-card .pill {
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.06em;
    text-transform: lowercase;
    color: var(--ink-mute);
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,0.02);
  }

  /* ===== Three experiences ===== */
  .exp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-top: 24px;
  }
  .exp-card {
    position: relative;
    padding: 32px 30px;
    border-radius: var(--radius-lg);
    background:
      linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.014)),
      rgba(17, 12, 36, 0.42);
    border: 1px solid rgba(190, 165, 255, 0.18);
    box-shadow: 0 28px 70px -48px rgba(0,0,0,0.85), inset 0 1px 0 rgba(255,255,255,0.05);
    overflow: hidden;
    min-height: 470px;
    display: flex;
    flex-direction: column;
  }
  .exp-card::before {
    content: "";
    position: absolute;
    inset: -1px -1px auto;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(232, 155, 255, 0.7), transparent);
    opacity: 0.65;
  }
  .exp-card:hover .exp-visual {
    transform: translateY(-4px);
    border-color: rgba(232, 155, 255, 0.36);
  }
  .exp-card .top {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 18px;
  }
  .exp-card .role {
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--violet-2);
  }
  .exp-card .dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--magenta);
    box-shadow: 0 0 12px var(--magenta);
  }
  .exp-card .num {
    font-family: 'Instrument Serif', serif;
    font-size: 68px;
    line-height: 0.85;
    background: var(--grad-text);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 20px;
    font-style: italic;
    font-weight: 400;
    opacity: 0.85;
  }
  .exp-card h3 {
    font-size: 24px;
    font-weight: 500;
    letter-spacing: -0.015em;
    margin-bottom: 14px;
  }
  .exp-card p {
    color: var(--ink-soft);
    font-size: 14.5px;
    line-height: 1.6;
    margin: 0 0 24px;
  }
  .exp-visual {
    position: relative;
    min-height: 158px;
    margin-bottom: 26px;
    padding: 16px;
    border-radius: 22px;
    border: 1px solid rgba(190, 165, 255, 0.18);
    background:
      radial-gradient(220px 130px at 75% 20%, rgba(232, 155, 255, 0.18), transparent 68%),
      linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.025));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
    overflow: hidden;
    transition: transform .35s ease, border-color .35s ease;
  }
  .visual-topline {
    display: flex;
    gap: 6px;
    margin-bottom: 14px;
  }
  .visual-topline span {
    width: 32px;
    height: 7px;
    border-radius: 999px;
    background: rgba(255,255,255,0.14);
  }
  .visual-kpis {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-bottom: 12px;
  }
  .visual-kpis span {
    padding: 12px;
    border-radius: 14px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.06);
  }
  .visual-kpis strong {
    display: block;
    font-size: 22px;
    line-height: 1;
    font-family: 'Instrument Serif', serif;
    font-weight: 400;
  }
  .visual-kpis small {
    display: block;
    margin-top: 4px;
    color: var(--ink-mute);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: .12em;
  }
  .admin-visual svg { width: 100%; height: 66px; display: block; overflow: visible; }
  .admin-visual .chart-line {
    stroke: var(--violet);
    stroke-width: 4;
    stroke-linecap: round;
    filter: drop-shadow(0 0 10px rgba(160,132,255,.55));
  }
  .admin-visual .chart-fill { fill: rgba(160,132,255,.14); }
  .admin-visual circle { fill: var(--magenta); }
  .staff-visual {
    display: grid;
    gap: 10px;
  }
  .staff-row {
    display: grid;
    grid-template-columns: 46px 4px 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 16px;
    color: var(--ink-soft);
    background: rgba(255,255,255,0.045);
  }
  .staff-row.active {
    background: rgba(160, 132, 255, 0.18);
    color: var(--ink);
  }
  .staff-row time { color: var(--ink-mute); font-size: 13px; }
  .staff-row > span {
    height: 34px;
    border-radius: 999px;
    background: var(--violet);
  }
  .staff-row:nth-child(2) > span { background: var(--gold); }
  .staff-row strong { font-size: 15px; }
  .staff-row em {
    font-style: normal;
    font-size: 11px;
    padding: 5px 9px;
    border-radius: 999px;
    background: rgba(255,255,255,0.1);
    color: var(--ink);
  }
  .staff-actions {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
  }
  .staff-actions span {
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
    color: var(--ink-soft);
    font-size: 11px;
  }
  .client-visual {
    display: grid;
    align-content: center;
    gap: 12px;
  }
  .booking-steps {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .booking-steps span {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(255,255,255,0.08);
    color: var(--ink-mute);
    font-size: 12px;
    font-weight: 600;
  }
  .booking-steps span.done {
    background: var(--grad-cta);
    color: #fff;
    box-shadow: 0 10px 26px -16px rgba(160,132,255,.8);
  }
  .booking-choice,
  .booking-time {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 13px 14px;
    border-radius: 16px;
    background: rgba(255,255,255,0.075);
    border: 1px solid rgba(255,255,255,0.06);
  }
  .booking-choice strong,
  .booking-time span { font-size: 15px; }
  .booking-choice small { color: var(--ink-mute); }
  .booking-time button {
    padding: 8px 13px;
    border-radius: 999px;
    background: var(--grad-cta);
    color: #fff;
    font-weight: 600;
    font-size: 12px;
  }
  .pills {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin-top: auto;
  }
  .pill {
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.06em;
    color: var(--ink-soft);
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(160, 132, 255, 0.06);
    border: 1px solid var(--line);
  }

  /* ===== Automation ===== */
  .auto-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 56px;
    align-items: start;
  }
  .auto-left { display: flex; flex-direction: column; }
  .auto-left .section-head { margin-bottom: 28px; max-width: 520px; }
  .auto-list { display: grid; gap: 14px; }
  /* Phone sits lower so its bottom visually aligns with the feature stack. */
  #automatizacija .wa-stage {
    align-self: end;
    justify-self: center;
    align-items: center;
    width: min(380px, 100%);
    padding-top: 0;
    margin-top: 0;
    padding-bottom: 0;
  }
  .auto-item {
    display: flex;
    gap: 18px;
    padding: 22px 24px;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
    transition: border-color .3s ease, background .3s ease;
  }
  .auto-item:hover {
    border-color: var(--line-strong);
    background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.005));
  }
  .auto-item .ico {
    width: 40px; height: 40px;
    border-radius: 10px;
    display: grid; place-items: center;
    background: linear-gradient(135deg, rgba(160, 132, 255, 0.2), rgba(232, 155, 255, 0.08));
    border: 1px solid var(--line-strong);
    color: var(--violet-2);
    flex-shrink: 0;
  }
  .auto-item .ico svg { width: 18px; height: 18px; }
  .auto-item h4 {
    font-size: 16.5px;
    font-weight: 500;
    margin: 0 0 4px;
    letter-spacing: -0.01em;
  }
  .auto-item p {
    margin: 0;
    color: var(--ink-soft);
    font-size: 14px;
    line-height: 1.55;
  }

  /* ===== WhatsApp iPhone simulation ===== */
  .wa-phone {
    position: relative;
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
    aspect-ratio: 9 / 17.45;
    background: #1c1c1e;
    border-radius: 44px;
    padding: 12px;
    box-shadow:
      0 0 0 2px #2a2a2c,
      0 0 0 4px #0a0a0c,
      0 40px 100px -20px rgba(0,0,0,0.7),
      0 0 80px -10px rgba(160, 132, 255, 0.35);
  }
  .wa-phone::before {
    /* notch */
    content: "";
    position: absolute;
    top: 12px; left: 50%;
    transform: translateX(-50%);
    width: 110px; height: 28px;
    background: #0a0a0c;
    border-radius: 0 0 18px 18px;
    z-index: 5;
  }
  .wa-screen {
    width: 100%; height: 100%;
    background: #efeae2;
    border-radius: 32px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
  }
  .wa-statusbar {
    height: 38px;
    background: #008069;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 22px 0 28px;
    color: white;
    font-size: 13px;
    font-weight: 600;
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', system-ui, sans-serif;
    flex-shrink: 0;
    padding-top: 4px;
  }
  .wa-statusbar .wa-time { letter-spacing: -0.02em; }
  .wa-statusbar .wa-icons {
    display: flex;
    gap: 5px;
    align-items: center;
  }
  .wa-statusbar .wa-icons svg {
    width: 16px; height: 11px;
    fill: white;
  }
  .wa-header {
    background: #008069;
    padding: 8px 14px 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: white;
    flex-shrink: 0;
    font-family: -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  }
  .wa-back {
    color: white;
    font-size: 22px;
    line-height: 1;
    padding: 0;
    width: 18px;
  }
  .wa-back svg { width: 11px; height: 18px; fill: white; }
  .wa-avatar-h {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #B591FF, #6E3CFF);
    display: grid; place-items: center;
    color: white;
    font-weight: 700;
    font-size: 14px;
    flex-shrink: 0;
    box-shadow: 0 0 0 2px rgba(255,255,255,0.15);
  }
  .wa-info { flex: 1; min-width: 0; }
  .wa-name {
    font-size: 14.5px;
    font-weight: 600;
    letter-spacing: -0.005em;
    color: white;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .wa-status {
    font-size: 11.5px;
    color: rgba(255,255,255,0.85);
    line-height: 1.2;
    margin-top: 1px;
    font-weight: 400;
  }
  .wa-actions {
    display: flex;
    gap: 16px;
    align-items: center;
    color: white;
  }
  .wa-actions svg { width: 18px; height: 18px; fill: white; }

  .wa-chat {
    flex: 1;
    background:
      url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'><g fill='%23000000' fill-opacity='0.025'><path d='M14 16c2-1 4-1 6 0M30 28c2-2 5-2 7 0M52 12c1 2 1 4 0 6M62 36c-2 1-4 0-5-2M22 50c-1 2-3 3-5 2M44 60c2-1 4 0 5 2M64 64c-1-2 0-4 2-5'/></g></svg>"),
      #efeae2;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 7px 8px 3px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .wa-chat::-webkit-scrollbar { display: none; }
  .wa-date {
    align-self: center;
    background: rgba(255,255,255,0.85);
    color: #54656f;
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 8px;
    margin: 4px 0 6px;
    box-shadow: 0 1px 0.5px rgba(0,0,0,0.13);
    font-weight: 500;
  }
  .wa-msg {
    max-width: 78%;
    padding: 6px 9px 8px;
    border-radius: 8px;
    font-size: 13.5px;
    line-height: 1.32;
    color: #111b21;
    position: relative;
    box-shadow: 0 1px 0.5px rgba(0,0,0,0.13);
    word-wrap: break-word;
    opacity: 0;
    letter-spacing: -0.005em;
  }
  .wa-msg.in {
    background: white;
    align-self: flex-start;
    border-top-left-radius: 0;
    margin-left: 6px;
  }
  .wa-msg.in::before {
    content: "";
    position: absolute;
    top: 0; left: -8px;
    width: 8px; height: 13px;
    background:
      radial-gradient(circle at 0% 0%, transparent 8px, white 8.5px);
  }
  .wa-msg.out {
    background: #d9fdd3;
    align-self: flex-end;
    border-top-right-radius: 0;
    margin-right: 6px;
  }
  .wa-msg.out::before {
    content: "";
    position: absolute;
    top: 0; right: -8px;
    width: 8px; height: 13px;
    background:
      radial-gradient(circle at 100% 0%, transparent 8px, #d9fdd3 8.5px);
  }
  .wa-msg-time {
    font-size: 10px;
    color: #667781;
    float: right;
    margin: 6px -2px -2px 8px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    white-space: nowrap;
  }
  .wa-msg.out .wa-msg-time { color: #5e7a6a; }
  .wa-tick {
    width: 14px; height: 10px;
    display: inline-block;
    color: #53bdeb;
  }
  .wa-tick svg { width: 14px; height: 10px; fill: currentColor; }

  .wa-typing {
    align-self: flex-start;
    background: white;
    padding: 9px 14px;
    border-radius: 8px;
    border-top-left-radius: 0;
    margin-left: 6px;
    box-shadow: 0 1px 0.5px rgba(0,0,0,0.13);
    display: flex;
    gap: 4px;
    align-items: center;
    opacity: 0;
    position: relative;
  }
  .wa-typing::before {
    content: "";
    position: absolute;
    top: 0; left: -8px;
    width: 8px; height: 13px;
    background: radial-gradient(circle at 0% 0%, transparent 8px, white 8.5px);
  }
  .wa-typing span {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #98a2a8;
    animation: waDot 1.2s infinite ease-in-out;
  }
  .wa-typing span:nth-child(2) { animation-delay: 0.15s; }
  .wa-typing span:nth-child(3) { animation-delay: 0.3s; }

  @keyframes waDot {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.5; }
    30% { transform: translateY(-4px); opacity: 1; }
  }
  @keyframes waMsgIn {
    from { opacity: 0; transform: translateY(8px) scale(0.97); }
    to { opacity: 1; transform: translateY(0) scale(1); }
  }
  @keyframes waTypingHide {
    to { opacity: 0; transform: scale(0.85); height: 0; padding: 0; margin: 0; }
  }

  .wa-msg.m1 { animation-delay: 0.4s; }
  .wa-msg.m2 { animation-delay: 1.2s; }
  .wa-msg.m3 { animation-delay: 3.35s; }
  .wa-msg.m4 { animation-delay: 4.25s; }
  .wa-msg.m5 { animation-delay: 5.05s; }

  .wa-stage.in .wa-msg {
    animation-name: waMsgIn;
    animation-duration: 0.45s;
    animation-timing-function: cubic-bezier(.2,.8,.2,1);
    animation-fill-mode: forwards;
  }
  .wa-stage.in .wa-typing {
    animation: waMsgIn 0.45s ease-out 2.05s forwards, waTypingHide 0.35s ease-in 3.05s forwards;
  }

  .wa-input {
    background: #f0f2f5;
    padding: 6px 8px;
    display: flex;
    gap: 8px;
    align-items: center;
    flex-shrink: 0;
    padding-bottom: 10px;
  }
  .wa-input-bar {
    flex: 1;
    background: white;
    border-radius: 22px;
    padding: 9px 14px;
    color: #667781;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: -apple-system, system-ui, sans-serif;
  }
  .wa-input-bar svg { width: 18px; height: 18px; color: #667781; flex-shrink: 0; }
  .wa-input-bar .placeholder { color: #667781; }
  .wa-mic {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: #008069;
    display: grid; place-items: center;
    flex-shrink: 0;
    color: white;
    transition: transform 0.2s ease;
  }
  .wa-mic:hover { transform: scale(1.08); }
  .wa-mic svg { width: 18px; height: 18px; fill: white; }

  /* WhatsApp stage — badge above the phone (not overlapping) */
  .wa-stage {
    position: relative;
    padding: 4px 0 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }
  .wa-stage::before {
    content: "";
    position: absolute;
    inset: 60px 5% 30px 5%;
    background: radial-gradient(60% 60% at 50% 60%, rgba(0, 128, 105, 0.18) 0%, transparent 70%);
    filter: blur(40px);
    z-index: 0;
    pointer-events: none;
  }
  .wa-stage > .wa-phone { position: relative; z-index: 1; }
  .wa-stage .wa-badge {
    position: relative;
    align-self: center;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.2em;
    color: var(--ink-soft);
    padding: 8px 16px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(0, 200, 130, 0.10), rgba(0, 200, 130, 0.04));
    border: 1px solid rgba(0, 200, 130, 0.35);
    z-index: 2;
    text-transform: uppercase;
    box-shadow: 0 6px 20px -8px rgba(0, 200, 130, 0.4);
  }
  .wa-pulse {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #25D366;
    box-shadow: 0 0 10px #25D366;
    animation: none;
  }
  .wa-stage.in .wa-pulse {
    animation: waPulse 1.6s ease-in-out infinite;
  }
  @keyframes waPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.55; transform: scale(0.85); }
  }

  /* ===== Testimonials ===== */
  .testi-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }
  .testi-card {
    position: relative;
    padding: 30px 28px 26px;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008));
    border: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    transition: border-color .3s ease, transform .3s ease;
  }
  .testi-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-6px) rotate(-0.4deg);
    background: linear-gradient(180deg, rgba(232, 155, 255, 0.06), rgba(255,255,255,0.015));
    box-shadow: 0 24px 60px -28px rgba(232, 155, 255, 0.45);
  }
  .testi-stars {
    display: flex; gap: 3px; margin-bottom: 18px;
    color: var(--gold);
  }
  .testi-stars svg { width: 16px; height: 16px; fill: currentColor; }
  .testi-quote {
    font-size: 16px;
    line-height: 1.6;
    color: var(--ink);
    margin: 0 0 24px;
    font-weight: 400;
  }
  .testi-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: auto;
    padding-top: 20px;
    border-top: 1px solid var(--line);
  }
  .testi-avatar {
    width: 42px; height: 42px;
    border-radius: 50%;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--violet-2), var(--violet));
    display: grid; place-items: center;
    color: white;
    font-weight: 500;
    font-size: 16px;
    letter-spacing: -0.01em;
  }
  .testi-name {
    font-size: 14.5px;
    font-weight: 500;
    color: var(--ink);
    line-height: 1.2;
  }
  .testi-role {
    font-size: 12px;
    color: var(--ink-mute);
    font-family: 'Geist Mono', monospace;
    letter-spacing: 0.06em;
    margin-top: 3px;
  }

  /* ===== Pricing ===== */
  .pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }
  .price-card {
    position: relative;
    padding: 36px 32px 32px;
    border-radius: var(--radius-xl);
    background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.005));
    border: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    transition: border-color .35s ease, transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease;
  }
  .price-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-6px);
    box-shadow: 0 30px 70px -30px rgba(160, 132, 255, 0.55);
  }
  .price-card.featured:hover {
    transform: translateY(-10px) scale(1.015);
    box-shadow: 0 40px 100px -32px rgba(138, 92, 255, 0.7);
  }
  .price-card.featured {
    border-color: rgba(232, 155, 255, 0.35);
    background:
      linear-gradient(180deg, rgba(232, 155, 255, 0.08), rgba(160, 132, 255, 0.02)),
      radial-gradient(120% 60% at 50% 0%, rgba(232, 155, 255, 0.18), transparent 70%);
    box-shadow: 0 30px 80px -30px rgba(138, 92, 255, 0.4);
  }
  .price-card.featured::before {
    content: "Najpopularnije";
    position: absolute;
    top: -1px; left: 50%; transform: translateX(-50%) translateY(-50%);
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: white;
    padding: 7px 16px;
    border-radius: 999px;
    background: var(--grad-cta);
    box-shadow: 0 8px 30px -8px rgba(138, 92, 255, 0.6);
  }
  .price-card .plan {
    font-family: 'Geist Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--violet-2);
    margin-bottom: 16px;
  }
  .price-card .price {
    display: flex; align-items: baseline; gap: 6px;
    margin-bottom: 8px;
  }
  .price-card .price .amt {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: 56px;
    font-weight: 500;
    letter-spacing: -0.03em;
    line-height: 1;
  }
  .price-card .price .per {
    color: var(--ink-mute);
    font-size: 14.5px;
  }
  .price-card .desc {
    color: var(--ink-soft);
    font-size: 14px;
    margin-bottom: 28px;
  }
  .price-card .trial {
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--magenta);
    margin-bottom: 22px;
    display: flex; align-items: center; gap: 8px;
  }
  .price-card .trial::before {
    content: ""; width: 6px; height: 6px; border-radius: 50%;
    background: var(--magenta); box-shadow: 0 0 10px var(--magenta);
  }
  .features-list {
    list-style: none; padding: 0; margin: 0 0 32px;
    display: grid; gap: 12px;
  }
  .features-list li {
    display: flex; gap: 12px; align-items: flex-start;
    color: var(--ink-soft);
    font-size: 14.5px;
  }
  .features-list li svg {
    width: 18px; height: 18px;
    color: var(--magenta);
    flex-shrink: 0;
    margin-top: 1px;
  }
  .price-card .btn {
    width: 100%;
    justify-content: center;
    margin-top: auto;
  }
  .price-card .btn-soft {
    background: rgba(255,255,255,0.05);
    color: var(--ink);
    border: 1px solid var(--line-strong);
  }
  .price-card .btn-soft:hover {
    background: rgba(255,255,255,0.08);
  }

  .pricing-note {
    margin-top: 32px;
    text-align: center;
    color: var(--ink-mute);
    font-size: 14px;
  }

  /* ===== FAQ ===== */
  .faq-list {
    display: grid;
    gap: 12px;
    max-width: 820px;
    margin: 0 auto;
  }
  .faq-item {
    border-radius: var(--radius);
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.005));
    overflow: hidden;
    transition: border-color .3s ease;
  }
  .faq-item[open] { border-color: var(--line-strong); }
  .faq-q {
    list-style: none;
    padding: 22px 26px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    font-size: 16.5px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--ink);
    transition: background .25s ease;
  }
  .faq-q::-webkit-details-marker { display: none; }
  .faq-item:hover .faq-q { background: rgba(255,255,255,0.02); }
  .faq-icon {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(160, 132, 255, 0.1);
    border: 1px solid var(--line-strong);
    display: grid; place-items: center;
    color: var(--violet-2);
    flex-shrink: 0;
    transition: transform .3s ease, background .3s ease;
  }
  .faq-icon svg { width: 14px; height: 14px; }
  .faq-item[open] .faq-icon {
    transform: rotate(45deg);
    background: var(--grad-cta);
    color: white;
  }
  .faq-a {
    padding: 0 26px 24px;
    color: var(--ink-soft);
    font-size: 14.5px;
    line-height: 1.65;
    max-width: 70ch;
  }

  /* ===== Contact form ===== */
  .contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.05fr;
    gap: 72px;
    align-items: start;
  }
  .contact-info { max-width: 480px; }
  .contact-info .lead {
    color: var(--ink-soft);
    font-size: 15.5px;
    line-height: 1.7;
  }
  .contact-perks {
    list-style: none;
    padding: 0;
    margin: 36px 0 0;
    display: grid;
    gap: 14px;
  }
  .contact-perks li {
    display: flex;
    align-items: center;
    gap: 14px;
    color: var(--ink-soft);
    font-size: 14.5px;
    line-height: 1.5;
  }
  .perk-ico {
    width: 30px; height: 30px;
    border-radius: 50%;
    display: inline-grid; place-items: center;
    background: linear-gradient(135deg, rgba(160, 132, 255, 0.18), rgba(232, 155, 255, 0.08));
    border: 1px solid rgba(190, 165, 255, 0.28);
    color: var(--violet-2);
    flex-shrink: 0;
  }
  .perk-ico svg { width: 14px; height: 14px; }

  .contact-form {
    padding: 40px 36px;
    border-radius: var(--radius-xl);
    background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.01));
    border: 1px solid var(--line-strong);
    box-shadow: 0 30px 80px -40px rgba(138, 92, 255, 0.4), 0 1px 0 0 rgba(255,255,255,0.04) inset;
  }
  .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 16px;
  }
  .form-field { margin-bottom: 16px; display: block; }
  .form-field:last-of-type { margin-bottom: 18px; }
  .form-field label {
    display: block;
    font-family: 'Geist Mono', monospace;
    font-size: 10.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 9px;
  }
  .form-field input,
  .form-field textarea {
    width: 100%;
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(0,0,0,0.28);
    color: var(--ink);
    font-family: inherit;
    font-size: 14.5px;
    transition: border-color .25s ease, background .25s ease, box-shadow .25s ease;
    resize: vertical;
    box-sizing: border-box;
  }
  .form-field input::placeholder,
  .form-field textarea::placeholder { color: var(--ink-faint); }
  .form-field input:focus,
  .form-field textarea:focus {
    outline: none;
    border-color: rgba(232, 155, 255, 0.55);
    background: rgba(0,0,0,0.4);
    box-shadow: 0 0 0 3px rgba(232, 155, 255, 0.12);
  }
  .form-field textarea { min-height: 120px; line-height: 1.55; }
  .form-submit {
    margin-top: 4px;
    width: 100%;
    justify-content: center;
  }
  .form-note {
    margin-top: 14px;
    font-size: 12.5px;
    color: var(--ink-mute);
    text-align: center;
  }
  .form-success {
    display: none;
    padding: 14px 16px;
    border-radius: 12px;
    background: rgba(110, 231, 166, 0.1);
    border: 1px solid rgba(110, 231, 166, 0.3);
    color: #6EE7A6;
    font-size: 14px;
    margin-top: 14px;
  }
  .form-success.show { display: block; }

  /* ===== Final CTA ===== */
  .final-cta {
    text-align: center;
    padding: 88px 0 96px;
    position: relative;
  }
  .final-cta::before {
    content: "";
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 700px; height: 600px;
    background: radial-gradient(50% 50% at 50% 50%, rgba(160, 132, 255, 0.18), transparent 70%);
    pointer-events: none;
    z-index: -1;
  }
  .final-cta .display { margin: 18px auto 0; max-width: 14ch; }
  .final-cta .lead { margin: 20px auto 32px !important; }
  .final-cta .ctas {
    display: flex; justify-content: center; gap: 14px;
    margin-top: 32px;
    flex-wrap: wrap;
  }
  .final-cta .trust {
    margin-top: 18px;
    color: var(--ink-mute);
    font-size: 13px;
  }

  /* ===== Footer (minimal) ===== */
  footer.foot-min {
    border-top: 1px solid var(--line);
    padding: 44px 0 36px;
    color: var(--ink-mute);
    background: var(--bg);
    position: relative;
  }
  footer.foot-min::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(600px 200px at 50% 0%, rgba(160,132,255,0.06), transparent 70%);
    pointer-events: none;
  }
  .foot-min-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    text-align: center;
    position: relative;
    z-index: 1;
  }
  .foot-logo img {
    height: 30px;
    width: auto;
    display: block;
    opacity: 0.92;
    transition: opacity .25s ease;
  }
  .foot-logo:hover img { opacity: 1; }
  .foot-rights {
    margin: 0;
    font-size: 13px;
    color: var(--ink-mute);
    letter-spacing: -0.005em;
  }
  .foot-powered {
    margin: 0;
    font-family: 'Geist Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-faint);
  }
  .foot-powered a {
    color: var(--ink-soft);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color .2s ease, border-color .2s ease;
  }
  .foot-powered a:hover {
    color: var(--violet-2);
    border-bottom-color: var(--violet-2);
  }

  /* ===== Reveal animations ===== */
  .reveal {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.9s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.9s cubic-bezier(0.2, 0.8, 0.2, 1);
  }
  .reveal.in { opacity: 1; transform: translateY(0); }

  /* ===== Cookie banner ===== */
  .cookie-banner {
    position: fixed;
    bottom: 24px;
    left: 24px;
    right: 24px;
    max-width: 640px;
    margin: 0 auto;
    z-index: 100;
    padding: 20px 24px;
    border-radius: var(--radius-lg);
    background: rgba(20, 12, 36, 0.92);
    backdrop-filter: blur(18px);
    border: 1px solid var(--line-strong);
    box-shadow: 0 30px 80px -20px rgba(0,0,0,0.7), 0 0 0 1px rgba(255,255,255,0.04) inset;
    display: flex;
    align-items: center;
    gap: 22px;
    flex-wrap: wrap;
    transform: translateY(140%);
    transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
  }
  .cookie-banner.show { transform: translateY(0); }
  .cookie-banner .text {
    flex: 1;
    min-width: 240px;
  }
  .cookie-banner .text strong {
    display: block;
    font-size: 14.5px;
    font-weight: 500;
    color: var(--ink);
    margin-bottom: 4px;
    letter-spacing: -0.01em;
  }
  .cookie-banner .text p {
    margin: 0;
    color: var(--ink-mute);
    font-size: 13px;
    line-height: 1.55;
  }
  .cookie-banner .text a {
    color: var(--violet-2);
    text-decoration: underline;
    text-underline-offset: 2px;
  }
  .cookie-banner .actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
  }
  .cookie-btn {
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    transition: background .25s ease, transform .25s ease;
  }
  .cookie-btn.primary {
    background: var(--grad-cta);
    color: white;
    box-shadow: 0 6px 20px -6px rgba(138, 92, 255, 0.6);
  }
  .cookie-btn.primary:hover { transform: translateY(-1px); }
  .cookie-btn.ghost {
    color: var(--ink-soft);
    border: 1px solid var(--line-strong);
    background: transparent;
  }
  .cookie-btn.ghost:hover { background: rgba(255,255,255,0.04); color: var(--ink); }

  /* ===== Responsive ===== */
  /* ============= TABLET (≤1100px) ============= */
  @media (max-width: 1100px) {
    .hero { min-height: 0; }
    .hero-grid { grid-template-columns: 1fr; gap: 56px; text-align: center; }
    .hero-text { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
    .hero-text .lead { margin-left: auto; margin-right: auto; }
    .hero-ctas, .hero-trust { justify-content: center; margin-left: auto; margin-right: auto; }
    .hero-stats { margin-left: auto; margin-right: auto; }
    .phone-stage { height: clamp(540px, 58vh, 620px); }
    .auto-grid { grid-template-columns: 1fr; gap: 34px; }
    .auto-left { display: contents; }
    .auto-left .section-head { order: 0; }
    .auto-list { order: 1; max-width: 760px; width: 100%; margin: 0 auto; }
    .auto-grid .wa-stage { order: 2; max-width: 350px; margin: 0 auto; align-items: center; width: 100%; }
    #automatizacija .wa-stage { align-items: center; width: 100%; }
    #automatizacija .wa-stage .wa-badge { align-self: center; }
    .features-grid, .exp-grid, .pricing-grid, .steps-grid, .testi-grid { grid-template-columns: repeat(2, 1fr); }
    .industries-grid { grid-template-columns: repeat(3, 1fr); }
    /* Last item alone in row 2 → span all so it centers nicely */
    .contact-grid { grid-template-columns: 1fr; gap: 48px; }
    .section-head { margin-left: auto; margin-right: auto; text-align: center; }
    .section-head p, .section-head .lead { margin-left: auto; margin-right: auto; }
  }

  /* ============= MOBILE (≤860px — show hamburger) ============= */
  @media (max-width: 860px) {
    /* Header — hide desktop nav + CTA, show hamburger */
    .nav-links { display: none; }
    .login { display: none; }
    .cta-desktop { display: none; }
    .nav-right > .lang-switch { display: none; }
    .hamburger { display: inline-flex; }
    .mobile-lang-panel { display: block; }
  }

  /* ============= MOBILE (≤720px) ============= */
  @media (max-width: 720px) {
    .container { padding: 0 18px; max-width: 100%; }
    .site .container.nav { padding-left: 24px; padding-right: 24px; }
    section { padding: 56px 0; }
    .hero { padding: 40px 0 54px; }

    /* Header tightened */
    .nav { min-height: 84px; padding: 18px 0; gap: 14px; }
    .logo-img { height: 40px; object-fit: contain; }
    .nav-right { gap: 12px; display: flex; align-items: center; }
    .hamburger { width: 58px; height: 58px; border-radius: 19px; }
    .hamburger span { width: 27px; height: 2.4px; }
    .mobile-menu { padding: 118px 20px 36px; align-items: flex-start; overflow-y: auto; }
    .mobile-menu-inner { max-width: 410px; gap: 30px; }
    .mobile-nav { gap: 9px; }
    .mobile-nav a { padding: 20px 22px; font-size: 24px; border-radius: 20px; }
    .mobile-login { font-size: 17px !important; letter-spacing: 0.16em !important; }
    .mobile-cta { width: 100%; justify-content: center; padding: 17px 22px; font-size: 17px; }

    /* Typography — bigger hero title for impact */
    .display { font-size: clamp(52px, 13vw, 64px); line-height: 1.01; letter-spacing: -0.04em; }
    .h2 { font-size: clamp(34px, 9vw, 46px); line-height: 1.07; }
    h3 { font-size: clamp(22px, 5.8vw, 26px); line-height: 1.15; }
    .lead { font-size: 15px; line-height: 1.6; }
    .eyebrow { font-size: 10.5px; }

    /* HERO — fully centered, larger title */
    .hero-grid { grid-template-columns: 1fr; gap: 44px; text-align: center; }
    .hero-text { max-width: 100%; display: flex; flex-direction: column; align-items: center; padding: 0; }
    .hero-text .eyebrow { margin-bottom: 0; }
    .hero-text .display { margin-top: 30px; }
    .hero-text .lead { margin: 30px auto 0; max-width: 36ch; font-size: 17px; }
    .hero-ctas { justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 38px; width: 100%; max-width: 340px; }
    .hero-trust { justify-content: center; margin-top: 28px; text-align: center; max-width: 330px; margin-left: auto; margin-right: auto; }
    .hero-stats { grid-template-columns: repeat(3, 1fr); gap: 10px; max-width: 420px; margin: 42px auto 0; width: 100%; }
    .hero-stats .stat { text-align: center; padding: 14px 6px; }
    .stat .num { font-size: 22px; }
    .stat .lbl { font-size: 10.5px; letter-spacing: 0.06em; }

    /* Section heads centered */
    .section-head { text-align: center !important; margin-left: auto !important; margin-right: auto !important; margin-bottom: 32px !important; }
    .section-head .eyebrow { display: inline-flex; }
    .section-head p, .section-head .lead { margin-left: auto; margin-right: auto; max-width: 38ch; }

    /* Buttons — full-tap, no overflow */
    .btn { padding: 14px 22px; font-size: 15.5px; }
    .btn-primary, .btn-ghost { min-width: 0; }
    .hero-ctas .btn { flex: 1 1 auto; max-width: 100%; min-height: 54px; justify-content: center; font-size: 16.5px; }
    .ctas .btn { justify-content: center; }

    /* Grids → single col */
    .features-grid, .exp-grid, .pricing-grid, .steps-grid, .testi-grid, .auto-grid, .panel-grid {
      grid-template-columns: 1fr;
      gap: 14px;
    }
    /* Industries: clean 2-col cards */
    .industries-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
    .industries-grid .industry-card:last-child:nth-child(odd) {
      grid-column: 1 / -1;
      max-width: 280px;
      justify-self: center;
      width: 100%;
    }
    .industry-card {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      padding: 22px 14px;
      gap: 0;
    }
    .industry-card .ico { margin: 0 auto 12px; width: 48px; height: 48px; }
    .industry-card .ico svg { width: 22px; height: 22px; }
    .industry-card h4 { margin-bottom: 4px; font-size: 15px; }
    .industry-card p { font-size: 12.5px; line-height: 1.45; }

    /* Cards on mobile */
    .step-card { padding: 26px 22px; text-align: left; }
    .step-card .num { font-size: 52px; }
    .feat-card { padding: 24px 22px; }
    .price-card { padding: 28px 24px; }
    .exp-card { padding: 28px 24px; min-height: auto; }
    .exp-visual { min-height: 145px; margin-bottom: 22px; }

    /* Manifest */
    .manifest, .final-cta { padding: 64px 0; text-align: center; }
    .final-cta .display { font-size: clamp(36px, 8.8vw, 46px); }
    .final-cta .ctas { justify-content: center; flex-direction: column; gap: 10px; align-items: stretch; max-width: 320px; margin-left: auto; margin-right: auto; }
    .final-cta .btn { width: 100%; max-width: 100%; justify-content: center; }

    /* CONTACT */
    .contact-grid { grid-template-columns: 1fr; gap: 32px; text-align: center; }
    .contact-info { max-width: 100%; }
    .contact-info .lead { margin-left: auto; margin-right: auto; max-width: 36ch; }
    .contact-perks { margin: 28px auto 0; max-width: 320px; }
    .contact-perks li { justify-content: flex-start; text-align: left; }
    .contact-form { padding: 26px 20px; }
    .form-row { grid-template-columns: 1fr; gap: 0; margin-bottom: 0; }
    .form-row .form-field { margin-bottom: 14px; }

    /* Automation: text/cards first, WhatsApp animation after reservation rules */
    .auto-grid { grid-template-columns: 1fr; gap: 28px; }
    .auto-left { display: contents; }
    .auto-left .section-head { order: 0; }
    .auto-list { order: 1; max-width: 100%; }
    .auto-grid .wa-stage { order: 2; margin: 0 auto; align-items: center; width: 100%; }
    .wa-phone { max-width: 276px; width: 100%; aspect-ratio: 9 / 16.2; padding: 10px; border-radius: 38px; }
    .wa-phone::before { top: 10px; width: 92px; height: 22px; }
    .wa-screen { border-radius: 28px; }
    .wa-statusbar { height: 32px; font-size: 12px; padding: 2px 18px 0 24px; }
    .wa-header { padding: 7px 12px 8px; gap: 8px; }
    .wa-avatar-h { width: 31px; height: 31px; }
    .wa-name { font-size: 13px; }
    .wa-status { font-size: 10.5px; }
    .wa-actions { gap: 12px; }
    .wa-actions svg { width: 16px; height: 16px; }
    .wa-msg { font-size: 12px; line-height: 1.24; padding: 5px 8px 7px; max-width: 80%; }
    .wa-msg-time { font-size: 9px; margin-top: 5px; }
    .wa-date { font-size: 9.5px; padding: 3px 9px; margin: 3px 0 5px; }
    .wa-typing { padding: 7px 12px; }
    .wa-input { padding: 5px 7px 8px; gap: 6px; }
    .wa-input-bar { padding: 7px 12px; font-size: 12px; }
    .wa-mic { width: 32px; height: 32px; }
    .wa-stage { gap: 12px; padding-bottom: 8px; }
    .wa-stage::before { inset: 50px 12% 18px 12%; }

    /* Phone / hero phone visual */
    .float-card.fc-1 { left: 0; top: 6%; }
    .float-card.fc-2 { right: 0; top: 32%; }
    .float-card.fc-3 { left: 0; bottom: 8%; }
    .phone { width: min(260px, 72vw); height: 548px; transform: rotate(0); }
    .phone-stage { height: auto; min-height: 580px; padding: 12px 0; display: flex; align-items: center; justify-content: center; }
    .phone-screen { padding: 44px 14px 14px; }
    .phone-screen .ph-head { margin-bottom: 12px; }
    .ph-brand { grid-template-columns: 36px 1fr auto; gap: 8px; padding: 10px; border-radius: 18px; }
    .ph-logo { width: 36px; height: 36px; border-radius: 13px; }
    .phone-screen .ph-title { font-size: 16px; }
    .phone-screen .ph-sub { margin-bottom: 0; font-size: 10.5px; }
    .ph-live { font-size: 8.5px; padding: 5px 7px 5px 16px; }
    .ph-progress { margin: 10px 0 9px; }
    .ph-progress span { padding: 6px 4px; font-size: 9.5px; }
    .ph-service { padding: 7px 9px; border-radius: 15px; gap: 9px; }
    .ph-service .av { width: 29px; height: 29px; border-radius: 11px; }
    .ph-service .info .nm { font-size: 11.5px; }
    .ph-service .info .meta { font-size: 9.5px; }
    .ph-cal { margin-top: 10px; padding: 9px; }
    .ph-cal-grid { gap: 3px; }
    .ph-cal-grid .d { font-size: 9px; padding: 3px 0; }
    .ph-slots { gap: 5px; margin-top: 8px; }
    .ph-slots span { padding: 7px 4px; font-size: 9.5px; }
    .ph-confirm { margin-top: 8px; padding: 10px 9px; }

    /* FAQ — comfortable on mobile */
    .faq-list { gap: 10px; }
    .faq-q { padding: 16px 16px; font-size: 14.5px; gap: 12px; line-height: 1.4; text-align: left; }
    .faq-a { padding: 0 16px 18px; font-size: 13.5px; line-height: 1.62; text-align: left; }
    .faq-icon { width: 24px; height: 24px; }
    .faq-icon svg { width: 12px; height: 12px; }

    /* Footer */
    .foot-min { padding: 32px 0 28px; }
    .foot-min-inner { gap: 12px; }
    .foot-logo img { height: 24px; }
    .foot-rights { font-size: 12px; }
    .foot-powered { font-size: 10px; letter-spacing: 0.16em; }

    /* Cookie banner */
    .cookie-banner {
      left: 12px; right: 12px; bottom: 12px;
      padding: 16px 18px;
      flex-direction: column;
      text-align: center;
      gap: 14px;
      align-items: stretch;
      max-width: calc(100vw - 24px);
    }
    .cookie-banner .actions { width: 100%; justify-content: center; display: flex; gap: 10px; }
    .cookie-banner .actions .cookie-btn { flex: 1; }
  }

  /* ============= SMALL PHONES (≤460px) ============= */
  @media (max-width: 460px) {
    .container { padding: 0 16px; }
    .site .container.nav { padding-left: 21px; padding-right: 21px; }
    .display { font-size: clamp(49px, 12.2vw, 56px); line-height: 1.03; }
    .nav { min-height: 82px; padding: 17px 0; }
    .logo-img { height: 38px; }
    .hamburger { width: 56px; height: 56px; }
    .h2 { font-size: clamp(32px, 8.8vw, 40px); }
    h3 { font-size: clamp(21px, 6vw, 24px); }
    .hero-stats { gap: 6px; }
    .stat .num { font-size: 20px; }
    .stat .lbl { font-size: 9.5px; }
    .final-cta .display { font-size: clamp(32px, 8.5vw, 38px); }
    .hero-ctas { flex-direction: column; align-items: stretch; max-width: 100%; }
    .hero-ctas .btn { width: 100%; max-width: 100%; }
  }

  /* ============= EXTRA SMALL (≤380px) ============= */
  @media (max-width: 380px) {
    .display { font-size: 44px; }
    .h2 { font-size: 30px; }
    .industries-grid { grid-template-columns: 1fr; }
    .industries-grid .industry-card:last-child { max-width: 100%; }
    .industry-card { padding: 18px 18px; }
    .industry-card .ico { margin-bottom: 10px; }
  }
