      /* Ariata Display — OTF fajl iz assets/fonts/ */
      @font-face {
        font-family: 'Ariata Display';
        src: url('../fonts/ariata-display-regular.otf') format('opentype'),
             local('Ariata Display'), local('AriataDisplay');
        font-weight: 400;
        font-style: normal;
        font-display: swap;
      }
      /* Smooth scrollbar */
      html { scroll-behavior: smooth; }
      /* Hide scrollbar on menu-open body */
      body.menu-open { overflow: hidden; }
      /* Nav active underline */
      .nav-active { border-bottom: 6px solid #007ca8; }
      /* Backdrop blur fallback */
      .backdrop-nav { background: rgba(255,255,255,0.97); }
      .backdrop-nav-bot { background: rgba(246, 248, 249, 0.96); }
      /* Menu overlay */
      #menu-overlay { transform: translateX(-100%); transition: transform 0.35s cubic-bezier(0.4,0,0.2,1); }
      #menu-overlay.is-open { transform: translateX(0); }
      #menu-overlay .sticky{min-height: 80px;}
      /* Progress bar */
      #bar { width: 85px; }
      /* Weather widget style */
      .weather-box {
        background: rgba(0,87,118,0.075);
        border-left: 1px solid rgba(0, 87, 118, 0.05);
        flex: 0 0 auto;
      }
      .weather-value {
        white-space: nowrap;
      }
      .weather-value-nowrap {
        white-space: nowrap;
      }
      :root {
        --header-height-desktop: 141px;
        --header-height-tablet: 135px;
        --header-height-mobile: 85px;
        --page-gutter-desktop: 71px;
        --page-gutter-tablet: 32px;
        --page-gutter-mobile: 24px;
        --desktop-cta-width: 338px;
        --desktop-menu-width: 134px;
        --desktop-design-width: 1814;
        --desktop-scale: 1;
      }
      body {
        margin: 0;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        text-rendering: optimizeLegibility;
      }
      .home-page-shell {
        background: #ffffff;
      }
      .site-scale-shell {
        width: 100%;
      }
      .site-scale-frame {
        width: 100%;
      }
      @media (min-width: 1180px) {
        .site-scale-shell {
          display: flex;
          justify-content: center;
          align-items: flex-start;
        }
      }
      @media (min-width: 1180px) and (max-width: 1813px) {
        .site-scale-frame {
          width: calc(var(--desktop-design-width) * 1px);
          zoom: var(--desktop-scale);
          transform-origin: top center;
        }
      }
      footer .grid.grid-cols-1:after{
          content: "";
          display: inline-block;
          width: 154px;
          height: 154px;
          background-image: url(../images/lukabudva-footer.png);
          background-size: contain;
          background-repeat: no-repeat;
          margin-right: 8px;
          vertical-align: middle;
          position: absolute;
          top: 60px;
          right: 60px;
      }
      footer form{
          background: #1e1e1e;
          padding: 0px;
      }
      .pdflinks ul li:before{
              content: "";
              display: inline-block;
              width: 20px;
              height: 20px;
              background-image: url('../images/download-svg.svg');
              background-size: contain;
              background-repeat: no-repeat;
              margin-right: 8px;
              vertical-align: middle;
      }
      .pdflinks ul li{
          color: rgba(255, 255, 255, 0.70);
          font-family: Poppins;
          font-size: 12px;
          font-style: normal;
          font-weight: 400;
          line-height: 18px; /* 150% */
      }
      .hero-video{
          width: 100%;
      }
      .home-hero {
        position: relative;
        overflow: hidden;
        min-height: calc(100vh - var(--header-height-desktop));
        aspect-ratio: 1814 / 731;
        background-color: #0d2f3f;
        max-width: 100%;
      }
      .home-hero::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.18));
        pointer-events: none;
      }
      .hero-overlay {
        position: absolute;
        inset: 0;
        z-index: 2;
        pointer-events: none;
      }
      .hero-status-card {
        position: absolute;
        top: 0.1rem;
        left: 31.2%;
        display: grid;
        grid-template-columns: 138px minmax(0, 1fr);
        width: 453px;
        background: rgba(183, 197, 210, 0.88);
        border: 1px solid rgba(255, 255, 255, 0.62);
        border-radius: 6px;
        overflow: hidden;
        box-shadow: 0 18px 38px rgba(5, 24, 34, 0.12);
      }
      .hero-status-card > div {
        padding: 12px 22px 14px;
      }
      .hero-status-card > div + div {
        border-left: 1px solid rgba(255, 255, 255, 0.36);
      }
      .hero-status-label {
        display: block;
        margin-bottom: 10px;
        font-family: "Playfair Display", Georgia, serif;
        font-size: 0.9375rem;
        line-height: 1.2;
        color: rgba(255, 255, 255, 0.95);
      }
      .hero-status-value {
        display: block;
        font-family: Montserrat, sans-serif;
        font-size: 0.9375rem;
        font-weight: 700;
        line-height: 1.2;
        letter-spacing: 0.22rem;
        text-transform: uppercase;
        color: #ffffff;
      }
      .hero-status-value.hero-status-large {
        font-size: 0.8125rem;
        letter-spacing: 0.24rem;
        white-space: nowrap;
      }
      .hero-progress {
        position: absolute;
        left: 17.15%;
        right: 17.1%;
        bottom: 1.55rem;
        height: 6px;
        display: grid;
        grid-template-columns: 33.1% 66.9%;
        gap: 12px;
        align-items: center;
      }
      .hero-progress span {
        display: block;
        height: 4px;
        border-radius: 9999px;
      }
      .hero-progress .is-active {
        background: rgba(255, 255, 255, 0.96);
      }
      .hero-progress .is-rest {
        background: rgba(255, 255, 255, 0.35);
      }
      /* ── Brand Strip — dark teal (matches Figma) ── */
      .home-brand-strip {
        position: relative;
        overflow: hidden;
        min-height: 187px;
        background: #02394c;          /* primary-dark — Figma dark teal */
      }
      .home-brand-strip::before,
      .home-brand-strip::after {
        content: "";
        position: absolute;
        top: 0px;
        width: 417px;
        height: 214px;
        background: url('../images/logo-mark.svg');
          background-size: contain;
          background-repeat: no-repeat;
        opacity: 0.06;
        filter: brightness(10);       /* render white on dark bg */
        pointer-events: none;
      }
      .home-brand-strip::before {
        left: -60px;
      }
      .home-brand-strip::after {
          right: 192px;
          bottom: -65px;
          top: initial;
      }
      .brand-strip-inner {
        position: relative;
        z-index: 1;
        display: flex;
        align-items: flex-start;
        gap: 64px;
        width: min(1171px, calc(100% - 4rem));
        min-height: 187px;
        margin: 0 auto;
        padding: 38px 0 32px;
      }
      .brand-strip-mark {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        width: 49px;
        height: 32px;
      }
      .brand-strip-mark img {
        width: 49px;
        height: inherit;
        filter: brightness(0) invert(1); /* white icon on dark bg */
      }
      .brand-strip-copy {
        display: flex;
        flex-direction: column;
        gap: 18px;
      }
      .brand-strip-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        font-weight: 400;
        line-height: 1;
        color: #ffffff;               /* white on dark bg */
      }
      .brand-strip-subtitle {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: rgba(255, 255, 255, 0.72);
      }
      .home-intro-section {
        position: relative;
        overflow: hidden;
        min-height: 730px;
        background: #fafbfb;
      }
      .home-intro-pattern {
        position: absolute;
        top: 0;
        left: 0;
        width: 504px;
        height: 647px;
        object-fit: contain;
        opacity: 1;
        pointer-events: none;
      }
      .home-intro-watermark {
          position: absolute;
          right: 160px;
          bottom: 20%;
          width: 560px;
          height: auto;
          opacity: 0.035;
          pointer-events: none;
      }
      .home-intro-small-image {
        position: absolute;
        right: 0;
        bottom: 38px;
        width: 142px;
        height: 163px;
        object-fit: contain;
        pointer-events: none;
      }
      .home-intro-inner {
        position: relative;
        z-index: 1;
        width: min(1248px, calc(100% - 4rem));
        margin: 0 auto;
        padding-top: 67px;
      }
      .home-intro-kicker {
        display: block;
        margin-bottom: 32px;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        line-height: 1.2;
        letter-spacing: 1.4px;
        text-transform: uppercase;
        color: #005776;
      }
      .home-intro-title {
        max-width: 972px;
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        line-height: 1;
        color: #97b1ba;
      }
      .home-intro-text {
        max-width: 547px;
        margin: 24px 0 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #7c8087;
      }
      .home-intro-link {
        display: inline-flex;
        align-items: center;
        gap: 22px;
        margin-top: 40px;
        color: #0068ac;
        text-decoration: none;
      }
      .home-intro-play {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 90px;
        height: 90px;
        border-radius: 999px;
          background: #87d0f546;
      }
      .home-intro-play:hover{
          background: #87d0f565;
      }
      .home-intro-line {
        width: 117px;
        height: 1px;
        background: rgba(0, 87, 118, 0.18);
      }
      .home-intro-link-text {
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 600;
        line-height: 21px;
        color: #0068ac;
      }
      .infra-section {
        position: relative;
        overflow: hidden;
        background: #005776;
        padding: 0px 0 9.1875rem;

      }
      .infra-shell {
        position: relative;
        z-index: 2;
        width: min(1226px, calc(100% - 4rem));
        margin: 0 auto;
      }
      .infra-accent {
        width: 30px;
        height: 9px;
        margin: 0 auto 5.5625rem;
        background: #f5f5f5;
      }
      .infra-title {
        margin: 0 auto;
        max-width: 1072px;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 6rem;
        line-height: 1;
        text-align: center;
        color: #f5f5f5;
      }
      .infra-grid {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 178px));
        justify-content: center;
        gap: 38px 35px;
        width: 856px;
        margin: 5.5rem auto 0;
      }
      .infra-card {
        display: flex;
        flex-direction: column;
        align-items: center;
        background: #007CA8;
        border-radius: 12px;
        padding: 24px 14px 28px;
        cursor: pointer;
        transition: transform 0.2s ease, box-shadow 0.2s ease;
      }
      .infra-card:hover{
          transform: translateY(-3px);
          box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14);
      }
      .infra-card:focus-visible {
        outline: 2px solid #f5f5f5;
        outline-offset: 6px;
      }
      .infra-icon-wrap {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 64px;
        height: 64px;
        margin-bottom: 20px;
        flex-shrink: 0;
      }
      .infra-icon-wrap img {
        display: block;
        width: 64px;
        height: 64px;
        object-fit: contain;
      }
      .infra-card-title {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 18px;
        font-weight: 600;
        line-height: 1.25;
        text-align: center;
        color: #ffffff;
      }
      .infra-card-desc {
        margin: 8px 0 0;
        font-family: Poppins, sans-serif;
        font-size: 12px;
        line-height: 18px;
        text-align: center;
        color: rgba(255, 255, 255, 0.72);
      }
      .infra-modal {
        position: fixed;
        inset: 0;
        z-index: 9999;
      }
      .infra-modal[hidden] {
        display: none;
      }
      .infra-modal-backdrop {
        position: fixed;
        inset: 0;
        background:
          radial-gradient(circle at 11% 51%, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0) 4.5rem),
          radial-gradient(circle at 21% 27%, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 4rem),
          radial-gradient(circle at 28% 74%, rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0) 4rem),
          radial-gradient(circle at 79% 42%, rgba(255, 255, 255, 0.26), rgba(255, 255, 255, 0) 4rem),
          radial-gradient(circle at 90% 51%, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0) 4.5rem),
          radial-gradient(circle at 89% 73%, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0) 4rem),
          rgba(0, 39, 53, 0.56);
        backdrop-filter: blur(14px);
      }
      .infra-modal-dialog {
        position: fixed;
        top: 50%;
        left: 50%;
        z-index: 1;
        width: min(calc(100vw - 48px), 428px);
        min-height: 423px;
        padding: 40px 24px 34px;
        background: #0d6d8d;
        border-radius: 32px;
        box-shadow: 0 24px 70px rgba(0, 0, 0, 0.24);
        transform: translate(-50%, -50%);
      }
      .infra-modal-close {
        position: absolute;
        top: -68px;
        right: -82px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 56px;
        height: 56px;
        border: 1px solid rgba(245, 245, 245, 0.88);
        border-radius: 999px;
        background: transparent;
        color: #f5f5f5;
      }
      .infra-modal-close span {
        position: absolute;
        width: 18px;
        height: 1.5px;
        border-radius: 999px;
        background: currentColor;
      }
      .infra-modal-close span:first-child {
        transform: rotate(45deg);
      }
      .infra-modal-close span:last-child {
        transform: rotate(-45deg);
      }
      .infra-modal-icon {
        width: 112px;
        height: 112px;
        margin-bottom: 30px;
        margin-left: auto;
        margin-right: auto;
        border-radius: 999px;
        background: #f5f5f5 center center / 56px 56px no-repeat;
      }
      .infra-modal-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 50px;
        line-height: 1.08;
        text-align: left;
        color: #ffffff;
      }
      .infra-modal-divider {
        width: 38px;
        height: 7px;
        margin: 30px 0 28px;
        background: #f5f5f5;
      }
      .infra-modal-desc {
        margin: 0;
        font-family: Poppins, sans-serif;
        font-size: 18px;
        line-height: 1.62;
        text-align: left;
        color: rgba(255, 255, 255, 0.82);
        white-space: pre-line;
      }
      .infra-decor-left,
      .infra-decor-right {
        position: absolute;
        pointer-events: none;
          opacity: 0.02;
          width: 363px;
        height: auto;
      }
      .infra-decor-left {
          top: 60px;
          left: -40px;
      }
      .infra-decor-right {
          right: -40px;
          bottom: 200px;
          width: 423px;
      }
      .location-section {
        position: relative;
        overflow: hidden;
        min-height: 975px;
        background: #062332 url('../images/figmaassets/Vector 2.png') center / cover no-repeat;
        color: #ffffff;
      }
      .location-section::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.02) 52%, rgba(0, 0, 0, 0.16));
        pointer-events: none;
          width: 93%;
      }
      .location-shell {
        position: relative;
        z-index: 1;
        width: min(1252px, calc(100% - 4rem));
        min-height: 924px;
        margin: 0 auto;
        padding-top: 85px;
      }
      .location-head {
        display: flex;
        align-items: flex-end;
        justify-content: space-between;
        gap: 3rem;
        min-height: 349px;
        padding: 0 36px;
      }
      .location-copy {
        max-width: 702px;
        align-self: flex-start;
      }
      .location-kicker {
        display: block;
        margin-bottom: 12px;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 1.4px;
        line-height: 1.2;
        text-transform: uppercase;
        color: #87d0f5;
      }
      .location-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        line-height: 1;
        color: #ffffff;
      }
      .location-cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 200px;
        height: 55px;
        margin-bottom: 0;
        background: #ffffff;
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #0068ac;
        text-decoration: none;
        transition: transform 180ms ease, background-color 180ms ease;
      }
      .location-cta:hover {
        transform: translateY(-1px);
        background: #f5f5f5;
      }
      .location-separator {
        width: calc(100% - 72px);
        height: 1px;
        margin: 36px auto 0;
        background: rgba(255, 255, 255, 0.28);
      }
      .location-features {
        display: flex;
        flex-direction: column;
        gap: 26px;
        width: calc(100% - 72px);
        margin: 36px auto 0;
      }
      .location-feature {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 2rem;
        min-height: 130px;
      }
      .location-feature-copy {
        max-width: 487px;
      }
      .location-feature-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 32px;
        line-height: 1.5;
        color: #ffffff;
      }
      .location-feature-desc {
        margin: 8px 0 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: rgba(255, 255, 255, 0.76);
      }
      .location-feature-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 55px;
        height: 55px;
        border-radius: 999px;
        background: #007ca8;
        color: #ffffff;
        flex: 0 0 auto;
      }
      .location-feature-icon svg {
        width: 23px;
        height: 23px;
        transform: rotate(-45deg);
          transition: transform 0.3s ease;
      }
      .location-feature-icon:hover svg {
          transform: rotate(0deg);
      }
      /* ══════════════════════════════════════════════════════
         REZERVIŠITE KOMERCIJALNI VEZ
         Figma node 1035:7422 — card overlaps location section
         ══════════════════════════════════════════════════════ */
      .reservation-section {
        position: relative;
        z-index: 2;
        margin-top: -15px;  /* card overlaps bottom of location section */
        padding: 0 0 72px;
      }
      /* fafbfb background starts AFTER the overlap zone */
      .reservation-section::before {
        content: "";
        position: absolute;
        inset: 100px 0 0;
        background: #fafbfb;
        z-index: -1;
      }
      /* The card itself */
      .reservation-shell {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: min(1504px, calc(100% - 4rem));
        min-height: 696px;
        margin: 0 auto;
        border-radius: 12px;
        box-shadow: 0px 25px 50px -12px rgba(0, 0, 0, 0.25);
        overflow: hidden;
      }
      /* LEFT panel — Zašto Luka Budva? */
      .reservation-side {
        display: flex;
        flex-direction: column;
        gap: 32px;
        background: #fafbfb;
        padding: 96px 64px;
        align-self: flex-start;
      }
      /* RIGHT panel — form / Rezervišite */
      .reservation-form {
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        background: #f5f5f5;
        padding: 96px 64px;
      }
      .reservation-form-top {
        display: flex;
        flex-direction: column;
        gap: 96px;
      }
      /* Accent bar shared by both panels */
      .reservation-panel-head {
        display: flex;
        flex-direction: column;
        gap: 16px;
      }
      .reservation-accent {
        width: 30px;
        height: 4px;
        background: #005776;
        flex-shrink: 0;
      }
      .reservation-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 44px;
        line-height: 1;
        color: #859da6;
      }
      .reservation-copy {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #7c8087;
      }
      .reservation-cta {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        width: 100%;
        height: 53px;
        background: #005776;
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 600;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #ffffff;
        text-decoration: none;
        transition: background-color 180ms ease;
        filter: drop-shadow(0px 10px 7.5px rgba(0,0,0,0.1)) drop-shadow(0px 4px 3px rgba(0,0,0,0.1));
      }
      .reservation-cta:hover {
        background: #02394c;
      }
      .reservation-side-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 44px;
        line-height: 1;
        color: #859da6;
      }
      .reservation-list {
        display: flex;
        flex-direction: column;
        gap: 16px;
        margin: 0;
        padding: 24px 0;
        list-style: none;
      }
      .reservation-list li {
        display: flex;
        align-items: center;
        gap: 24px;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #7c8087;
      }
      .reservation-check {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 18px;
        height: 18px;
        border-radius: 999px;
        background: #005776;
        color: #ffffff;
        font-size: 10px;
        font-weight: 700;
        flex-shrink: 0;
      }
      .reservation-note {
        padding: 20px 20px 20px 24px;
        background: rgba(0, 104, 172, 0.1);
        border-left: 4px solid #0068ac;
        border-radius: 4px;
        font-family: Poppins, sans-serif;
        font-size: 13px;
        line-height: 24px;
        color: #54595f;
      }
      /* ══════════════════════════════════════════════════════
         BUDVA-DUBROVNIK FERRY SECTION
         Figma node 1035:7334
         ══════════════════════════════════════════════════════ */
      .ferry-section {
        display: grid;
        grid-template-columns: minmax(0, 1130px) minmax(0, 1fr);
        gap: 24px;
        align-items: stretch;
        min-height: 325px;
        padding: 0;
        overflow: hidden;
      }
      /* LEFT: image panel with gradient + text overlay */
      .ferry-visual {
        position: relative;
        overflow: hidden;
        background: #003f56;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-end;
        padding: 44px 18px 44px 205px;
        gap: 10px;
      }
      .ferry-visual > img {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        pointer-events: none;
      }
      /* Gradient overlay — dark at bottom for text legibility */
      .ferry-gradient {
        position: absolute;
        inset: 0;
        background: linear-gradient(0.432deg, rgba(0,0,0,0.38) 26%, rgba(0,0,0,0) 99%);
        pointer-events: none;
        z-index: 1;
      }
      /* "Budva-Dubrovnik" — sea image fills the letterforms */
      .ferry-title-clip {
        position: relative;
        z-index: 2;
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 96px;
        line-height: 96px;
        background-image: url('../images/figmaassets/Image%20with%20text.png');
        background-clip: text;
        -webkit-background-clip: text;
        color: #ffffff6e; 
        background-size: cover;
        background-position: center;
        white-space: nowrap;
          background: linear-gradient(180deg, #FFF -56%, rgba(255, 255, 255, 0.00) 170.67%);
          background-clip: text;
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent;
      }
      /* "Međunarodna linija" — plain white */
      .ferry-title-subtitle {
        position: relative;
        z-index: 2;
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        line-height: 1;
        color: #ffffff;
        white-space: nowrap;
      }
      /* RIGHT: content area */
      .ferry-content {
        display: flex;
        align-items: center;
        width: 100%;
      }
      .ferry-content-inner {
        width: 574px;
        max-width: calc(100% - 48px);
        display: flex;
        flex-direction: column;
        gap: 48px;
      }
      .ferry-upper {
        display: flex;
        flex-direction: column;
        gap: 12px;
      }
      .ferry-copy {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        line-height: normal;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #7c8087;
      }
      .ferry-learn-more {
        display: inline-flex;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        line-height: normal;
        letter-spacing: 1.4px;
        text-transform: uppercase;
        color: #005776;
        text-decoration: none;
        transition: color 180ms ease;
      }
      .ferry-learn-more:hover {
        color: #007ca8;
      }
      .ferry-actions {
        display: flex;
        gap: 36px;
        align-items: center;
      }
      .ferry-ticket {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 1 0 0;
        height: 55px;
        background: #005776;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #ffffff;
        text-decoration: none;
        transition: background-color 180ms ease;
      }
      .ferry-ticket:hover {
        background: #02394c;
      }
      .ferry-schedule {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 1 0 0;
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 600;
        line-height: 21px;
        color: #005776;
        text-decoration: none;
        transition: color 180ms ease;
        white-space: nowrap;
      }
      .ferry-schedule:hover {
        color: #007ca8;
      }
      /* ══════════════════════════════════════════════════════
         PREGLED DOSTUPNIH VEZOVA
         Figma node 1035:7037
         ══════════════════════════════════════════════════════ */
      .vezovi-section {
        background: var(--vezovi-bg-color, #f5f5f5);
        padding: 64px 214px 110px;
      }
      .vezovi-inner {
        display: flex;
        flex-direction: column;
        gap: 48px;
        align-items: center;
        width: 100%;
      }
      /* — header — */
      .vezovi-header {
        display: flex;
        flex-direction: column;
        gap: 22px;
        width: 100%;
      }
      .vezovi-accent {
        width: 30px;
        height: 4px;
        background: #005776;
        flex-shrink: 0;
      }
      .vezovi-title {
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        line-height: 1;
        color: #859da6;
        margin: 0;
      }
      .vezovi-subtitle {
        margin: 0;
        font-family: Poppins, sans-serif;
        font-size: 16px;
        line-height: 26px;
        color: #54595f;
        max-width: 697px;
      }
      /* — cards grid — */
      .vezovi-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 36px;
        width: 100%;
      }
      /* — LEFT card: Komercijalni — */
      .vezovi-card-komerc {
        background: #005776;
        display: flex;
        flex-direction: column;
        gap: 64px;
        padding: 48px 40px;
      }
      .vezovi-card-head {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
      }
      .vezovi-card-title-wrap {
        display: flex;
        flex-direction: column;
        gap: 8px;
      }
      .vezovi-card-title {
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 48px;
        line-height: 1;
        color: #ffffff;
        margin: 0;
      }
      .vezovi-card-title--grey { color: #859da6; }
      .vezovi-meta-white {
        font-family: Manrope, sans-serif;
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 2.4px;
        color: rgba(255, 255, 255, 0.8);
        margin: 0;
      }
      .vezovi-meta-dark {
        font-family: Manrope, sans-serif;
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 2.4px;
        color: #54595f;
        margin: 0;
      }
      .vezovi-count {
        font-family: Manrope, sans-serif;
        font-size: 64px;
        line-height: 1;
        font-weight: 400;
        margin: 0;
        flex-shrink: 0;
      }
      .vezovi-count--white { color: #ffffff; }
      .vezovi-count--blue  { color: #005776; }
      /* progress bars */
      .vezovi-bars {
        display: flex;
        flex-direction: column;
        gap: 20px;
      }
      .vezovi-bar-row {
        display: flex;
        flex-direction: column;
        gap: 8px;
      }
      .vezovi-bar-labels {
        display: flex;
        align-items: center;
        justify-content: space-between;
      }
      .vezovi-bar-label {
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #ffffff;
      }
      .vezovi-bar-track {
        height: 8px;
        border-radius: 9999px;
        overflow: hidden;
      }
      .vezovi-bar-track--1 { background: rgba(255,255,255,0.2); }
      .vezovi-bar-track--2 { background: #005085; }
      .vezovi-bar-track--3 { background: #02394c; }
      .vezovi-bar-track--4 { background: #02394c; }
      .vezovi-bar-fill {
        background: #87d0f5;
        height: 8px;
        border-radius: 9999px;
        width: 0;
        transition: width 1.15s cubic-bezier(0.22, 1, 0.36, 1);
      }
      .vezovi-section.is-animated .vezovi-bar-fill {
        width: var(--target-width, 0);
      }
      .vezovi-card-footer {
        border-top: 1px solid rgba(255,255,255,0.2);
        padding-top: 33px;
      }
      .vezovi-card-footer p {
        font-family: Manrope, sans-serif;
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 2.4px;
        color: rgba(255,255,255,0.8);
        margin: 0;
      }
      /* — RIGHT card: Komunalni — */
      .vezovi-card-komu {
        background: #fafbfb;
        border: 1px solid #e5e5e5;
        display: flex;
        flex-direction: column;
        gap: 82px;
        padding: 48px 41px;
      }
      /* checklist */
      .vezovi-checklist {
        display: flex;
        flex-direction: column;
        gap: 36px;
      }
      .vezovi-check-item {
        display: flex;
        align-items: flex-start;
        gap: 12px;
      }
      .vezovi-check-icon {
        width: 24px;
        height: 24px;
        background: #005776;
        border-radius: 9999px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        font-family: Manrope, sans-serif;
        font-size: 12px;
        font-weight: 700;
        color: #ffffff;
        line-height: 1;
      }
      .vezovi-check-body {
        display: flex;
        flex-direction: column;
        gap: 12px;
      }
      .vezovi-check-title {
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #005776;
        margin: 0;
      }
      .vezovi-check-desc {
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #54595f;
        margin: 0;
      }
      .vezovi-komu-link {
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 600;
        line-height: 21px;
        color: #005776;
        text-decoration: none;
        transition: color 180ms ease;
      }
      .vezovi-komu-link:hover { color: #007ca8; }
      /* — Applications box — */
      .vezovi-apps {
        background: #ffffff;
        border: 1px solid #007ca8;
        border-radius: 24px;
        padding: 36px 48px 36px;
        display: flex;
        align-items: center;
        gap: 32px;
        width: 100%;
        box-shadow: 0px -1px 48px rgba(0,0,0,0.25);
      }
      .vezovi-apps-text {
        flex: 1 0 0;
        display: flex;
        flex-direction: column;
        gap: 32px;
          margin-top: -36px;
      }
      .vezovi-apps-accent {
        width: 30px;
        height: 4px;
        background: #005776;
        flex-shrink: 0;
      }
      .vezovi-apps-title {
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 40px;
        line-height: 1;
        color: #859da6;
        margin: 0;
      }
      .vezovi-apps-links {
        border-left: 1px solid #abb0ba;
        padding-left: 24px;
        display: flex;
        align-items: flex-end;
        justify-content: flex-end;
        gap: 24px;
        width: 605px;
        flex-shrink: 0;
      }
      /* WalkDock wrapper — stretches to fill container height, spaces img+link apart */
      .vezovi-app-item--walkdock {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        width: 254px;
        align-self: stretch;
      }
      /* WalkDock image — aspect ratio 508:116 */
      .vezovi-walkdock-img {
        display: block;
        width: 100%;
        aspect-ratio: 508 / 116;
        object-fit: cover;
        border-radius: 8px;
      }
      /* WeatherLink wrapper */
      .vezovi-app-item--weather {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 12px;
        width: 244px;
        flex-shrink: 0;
      }
      /* WeatherLink container — dark card with green bottom border */
      .vezovi-weather-wrap {
        background: #3c464c;
        border-radius: 8px;
        border-bottom: 19px solid #5d9265;
        height: 58px;
        width: 100%;
        position: relative;
        overflow: hidden;
        filter: drop-shadow(0px 1px 6px rgba(0,0,0,0.25));
        flex-shrink: 0;
      }
      /* WeatherLink icon — centered 57×57 */
      .vezovi-weather-wrap img {
        position: absolute;
        top: 0.5px;
        left: calc(50% + 0.5px);
        transform: translateX(-50%);
        width: 57px;
        height: 57px;
        object-fit: cover;
      }
      .vezovi-app-link {
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 600;
        line-height: 21px;
        color: #0068ac;
        text-decoration: none;
        text-align: center;
        width: 100%;
        transition: color 180ms ease;
      }
      .vezovi-app-link:hover { color: #005776; }

      .experience-section {
        position: relative;
        overflow: hidden;
          padding: 190px 0 322px;
        background:
          #0b455d url('../images/experience-section-bg.webp') center center / cover no-repeat;
      }
      .experience-wave {
        position: absolute;
        top: 69px;
        left: -65px;
        width: calc(100% + 130px);
        opacity: 0.6;
        pointer-events: none;
        user-select: none;
      }
      .experience-bg-left {
        display: none;
      }
      .experience-bg-right {
        display: none;
      }
      .experience-shell {
        position: relative;
        z-index: 1;
        display: flex;
        flex-direction: column;
        gap: 48px;
        width: min(1494px, calc(100% - 426px));
        margin: 0 auto;
      }
      .experience-header {
        display: flex;
        flex-direction: column;
        gap: 38px;
      }
      .experience-accent {
        width: 30px;
        height: 4px;
        background: #ffffff;
      }
      .experience-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 96px;
        line-height: 96px;
        color: #f9fbf3;
      }
      .experience-copy {
        width: 539px;
        max-width: 100%;
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #ffffff;
      }
      .experience-cards {
        display: flex;
        gap: 24px;
        height: 678px;
        align-items: stretch;
      }
      .experience-card {
        position: relative;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        min-width: 0;
        padding: 24px;
        border-radius: 12px;
        overflow: hidden;
        color: #f9fbf3;
        isolation: isolate;
        cursor: pointer;
        flex: 0 0 237px;
        width: 237px;
        transition: flex-basis 320ms ease, width 320ms ease, transform 240ms ease, box-shadow 240ms ease, border-radius 240ms ease;
      }
      .experience-card-active {
        flex: 1 1 0;
        width: auto;
      }
      .experience-card:hover {
        transform: translateY(-2px);
      }
      .experience-card:focus-visible {
        outline: 2px solid rgba(255,255,255,0.9);
        outline-offset: 4px;
      }
      .experience-card > img {
        position: absolute;
        inset: 0;
        z-index: -2;
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
      }
      .experience-card:hover > img {
        transform: scale(1.04);
      }
      .experience-card::after {
        content: "";
        position: absolute;
        inset: 0;
        z-index: -1;
        background: linear-gradient(180deg, rgba(0, 0, 0, 0.04) 0%, rgba(0, 0, 0, 0.1) 44%, rgba(0, 0, 0, 0.76) 100%);
      }
      .experience-card-top {
        position: relative;
        z-index: 2;
        display: flex;
        justify-content: flex-end;
        align-items: flex-start;
        width: 100%;
        transition: opacity 180ms ease, transform 220ms ease;
      }
      .experience-card-body {
        position: relative;
        z-index: 2;
        transition: opacity 180ms ease, transform 220ms ease;
      }
      .experience-tags {
        display: flex;
        flex-wrap: wrap;
        gap: 12px;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-6px);
        transition: opacity 220ms ease, transform 220ms ease, visibility 220ms ease;
      }
      .experience-card-active .experience-card-top {
        justify-content: space-between;
        gap: 24px;
      }
      .experience-card-active .experience-tags {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
      }
      .experience-tag {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 39px;
        padding: 10px 32px;
        border: 1px solid #f9fbf3;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.02);
        backdrop-filter: blur(14px);
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 1.4px;
        text-transform: uppercase;
        color: #f9fbf3;
      }
      .experience-arrow {
        position: relative;
        z-index: 3;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 64px;
        height: 64px;
        border-radius: 999px;
        background: #005776;
        flex: 0 0 auto;
      }
      .experience-arrow img {
        position: static;
        z-index: auto;
        width: 16px;
        height: 16px;
        transform: none;
      }
      .experience-card-is-switching .experience-tags,
      .experience-card-is-switching .experience-card-body {
        opacity: 0;
        transform: translateY(8px);
      }
      .experience-card-title {
        margin: 0 0 12px;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 32px;
        line-height: 1;
        color: #f9fbf3;
        transition: font-size 280ms ease, line-height 280ms ease, margin-bottom 280ms ease;
      }
      .experience-card-active .experience-card-title {
        margin-bottom: 16px;
        font-size: 96px;
        line-height: 96px;
      }
      .experience-card-copy {
        width: 188px;
        max-width: 100%;
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #f9fbf3;
        transition: width 280ms ease, opacity 280ms ease;
      }
      .experience-card-active .experience-card-copy {
        width: 434px;
      }
      .experience-pagination {
        display: flex;
        flex-direction: column;
        gap: 20px;
        width: 331px;
        color: #f9fbf3;
      }
      .experience-pagination-meta {
        display: flex;
        justify-content: space-between;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 1.4px;
        text-transform: uppercase;
      }
      .experience-pagination-bar {
        position: relative;
        height: 3px;
        width: 100%;
        background: rgba(249, 251, 243, 0.28);
        overflow: hidden;
      }
      .experience-pagination-track {
        position: absolute;
        inset: 0;
        background: rgba(249, 251, 243, 0.28);
      }
      .experience-pagination-progress {
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        width: 25%;
        background: #f9fbf3;
        transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1), width 320ms cubic-bezier(0.22, 1, 0.36, 1);
      }
      .service-community-section {
        position: relative;
        overflow: hidden;
        background: #fbfbfb;
      }
      .service-community-title {
        margin: 0 auto 20px;
        padding: 0 24px;
        text-align: center;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: clamp(44px, 3.9vw, 72px);
        font-weight: 400;
        line-height: 0.98;
        letter-spacing: -0.02em;
        color: #005776;
      }
      .service-community-panel {
        position: relative;
        min-height: 420px;
        background: #eef6f8;
          background-size: cover;
          overflow: hidden;
          background-image: url(../images/service-bg.webp);
          background-position: center;
      }
      .service-community-panel::before {
        content: "";
        position: absolute;
        z-index: 1;
        top: -91px;
        left: -3vw;
        width: 106vw;
        height: 194px;
        border-bottom: 8px solid #005776;
        border-radius: 0 0 50% 50% / 0 0 100% 100%;
        background: #ffffff;
        transform: rotate(-1.4deg);
        transform-origin: center bottom;
          display: none;
      }
      .service-community-panel::after {
          display: none;
        content: "";
        position: absolute;
        left: -6%;
        bottom: -105px;
        width: 112%;
        height: 190px;
        border-radius: 50% 50% 0 0 / 100% 100% 0 0;
        background: rgba(255, 255, 255, 0.72);
        pointer-events: none;
      }
      .service-community-inner {
        position: relative;
        z-index: 2;
        display: grid;
          grid-template-columns: minmax(0, 0.92fr) minmax(230px, 0.18fr)
        gap: 74px;
        align-items: center;
        width: min(1132px, calc(100% - 240px));
        margin: 0 auto;
        padding: 132px 0 80px;
      }
      .service-community-content {
        padding-left: 42px;
      }
      .service-community-kicker {
        display: block;
        margin-bottom: 18px;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #87d0f5;
      }
      .service-community-heading {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: clamp(42px, 3vw, 56px);
        font-weight: 400;
        line-height: 0.86;
        letter-spacing: -0.02em;
        color: #97b1ba;
      }
      .service-community-heading strong {
        font-weight: 400;
        color: #005776;
      }
      .service-community-copy {
        margin: 28px 0 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #54595f;
      }
      .service-community-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 28px 40px;
        align-items: center;
        margin-top: 42px;
      }
      .service-community-cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 312px;
        height: 55px;
        padding: 0 28px;
        background: #005776;
        font-family: Montserrat, sans-serif;
        font-size: 12px;
        font-weight: 700;
        letter-spacing: 3.2px;
        text-transform: uppercase;
        color: #ffffff;
        text-decoration: none;
      }
      .service-community-link {
        display: inline-flex;
        align-items: center;
        min-height: 55px;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        color: #005776;
        text-decoration: none;
      }
      .service-community-image {
        position: relative;
        width: 100%;
        height: 252px;
        margin: 0;
        overflow: hidden;
          display: none;
      }
      .service-community-image::after {
        content: "";
        position: absolute;
        left: -6%;
        bottom: -43px;
        width: 112%;
        height: 74px;
        border-radius: 50% 50% 0 0;
        background: #eef6f8;
      }
      .service-community-image img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
      }
      .office-hours-strip {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 35px;
        overflow: hidden;
        background: #00475a;
      }
      .office-hours-strip p {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 13px;
        font-weight: 700;
        line-height: 1;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: #ffffff;
      }
      .local-services-section {
        position: relative;
        overflow: hidden;
        padding: 66px 0 96px;
        background: #ffffff;
      }
      .local-services-section::before {
        content: "";
        position: absolute;
          left: 100px;
        top: 58px;
        width: 391px;
        height: 420px;
        background: url("../images/figmaassets/Decorative Image.png") center / contain no-repeat;
          opacity: 0.68;
        pointer-events: none;
      }
      .local-services-section::after {
        content: "";
        position: absolute;
        right: -14px;
        top: -1px;
        width: 315px;
        height: 786px;
        background: url("../images/figmaassets/Anchor Image.png") center / contain no-repeat;
        opacity: 0.48;
        pointer-events: none;
      }
      .local-services-list {
        position: relative;
        z-index: 1;
        width: min(1036px, calc(100% - 520px));
        margin: 0 auto;
      }
      .local-services-intro,
      .local-services-outro {
        position: relative;
        z-index: 1;
        width: min(1036px, calc(100% - 520px));
        margin: 0 auto;
      }
      .local-services-intro {
        margin-bottom: 38px;
      }
      .local-services-outro {
        margin-top: 38px;
      }
      .local-services-title {
        margin: 0 0 16px;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: clamp(40px, 3.3vw, 56px);
        line-height: 0.98;
        color: #97b1ba;
          margin-bottom: 80px;
      }
      .local-services-text {
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #54595f;
      }
      .local-services-text > *:first-child {
        margin-top: 0;
      }
      .local-services-text > *:last-child {
        margin-bottom: 0;
      }
      .local-service-row {
        display: grid;
        grid-template-columns: 100px 86px minmax(0, 1fr) 300px;
        gap: 42px;
        align-items: center;
        min-height: 178px;
        border-bottom: 1px solid #d7d7d7;
      }
      .local-service-row.noimage {
          grid-template-columns: 10px 6px minmax(0, 1fr) 300px;
      }
      .local-service-number {
          font-family: Manrope;
        font-size: 58px;
        font-weight: 400;
        line-height: 1;
        letter-spacing: -0.02em;
        color: #97b1ba;
          transition: color 180ms ease;
      }
      .local-service-row:hover .local-service-number {
        color: #005776;
      }
      .local-service-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 82px;
        height: 85px;
      }
      .local-service-icon img {
        display: block;
        width: auto;
        max-width: 82px;
        max-height: 85px;
        opacity: 0.44;
      }
      .local-service-copy h3 {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: clamp(42px, 3.1vw, 42px);
        font-weight: 400;
        line-height: 1;
        letter-spacing: -0.02em;
        color: #97b1ba;
      }
      .local-service-copy p {
        max-width: 520px;
        margin: 16px 0 0 !important;
        font-family: Montserrat, sans-serif;
        font-size: 15.5px;
        line-height: 23px;
        color: #54595f;
      }
      .local-service-thumb {
        display: block;
        width: 300px;
        height: 149px;
        object-fit: cover;
      }
      @media (min-width: 1600px) and (max-width: 1813px) {
        .local-services-list {
          width: min(1100px, calc(100% - 420px));
        }
        .local-service-row {
          grid-template-columns: 92px 74px minmax(0, 1fr) 280px;
          gap: 28px;
        }
        .local-service-copy h3 {
          font-size: clamp(40px, 2.8vw, 40px);
          white-space: nowrap;
        }
        .local-service-copy p {
          max-width: 100%;
        }
        .local-service-thumb {
          width: 280px;
          height: 140px;
        }
      }
      #standardi,
      #aktuelnosti {
        overflow: hidden;
      }
      footer {
        overflow: hidden;
      }
      .section-reveal {
        opacity: 0;
        transform: translateY(22px);
        transition:
          opacity 700ms cubic-bezier(0.22, 1, 0.36, 1),
          transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
        will-change: opacity, transform;
      }
      .section-reveal.is-visible {
        opacity: 1;
        transform: translateY(0);
      }
      .desktop-nav-link {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        height: 100%;
        padding: 0 1.5rem;
        border-bottom: 6px solid transparent;
        font-family: Montserrat, sans-serif;
        font-size: 0.875rem;
        font-weight: 700;
        letter-spacing: 0.175rem;
        text-transform: uppercase;
        white-space: nowrap;
        color: #005776;
        transition: color 220ms ease, border-color 220ms ease;
      }
      .header-actions {
        gap: 0 !important;
      }
      .header-actions .header-lang {
        margin-right: 1rem;
      }
      .header-actions .header-search-trigger {
        margin-right: 0.85rem;
      }
      .header-reserve-cta,
      .header-route-cta {
        width: var(--desktop-cta-width) !important;
      }
      .header-menu-trigger,
      .header-menu-spacer {
        width: var(--desktop-menu-width) !important;
      }
      .desktop-bottom-inner {
        position: relative;
      }
      .header-phone-row {
        padding-right: calc(var(--desktop-cta-width) + var(--desktop-menu-width));
      }
      .header-route-stack {
        position: absolute;
        top: 0;
        right: 0;
        display: flex;
        align-items: center;
        height: 100%;
      }
      .desktop-nav-link.is-active {
        color: #859da6;
        border-bottom-color: #007ca8;
      }
      .desktop-nav-link:hover {
        color: #007ca8;
      }
      .header-lang {
        position: relative;
      }
      .header-lang-button {
        display: inline-flex;
        align-items: center;
        gap: 0.625rem;
        padding: 0 0.75rem;
        height: 85px;
        font-family: Montserrat, sans-serif;
        font-size: 1rem;
        font-weight: 700;
        letter-spacing: 0.1rem;
        text-transform: uppercase;
        color: #005776;
      }
      .header-lang-menu {
        position: absolute;
        top: calc(100% - 12px);
        right: 0;
        min-width: 96px;
        padding: 0.5rem;
        border: 1px solid rgba(0, 87, 118, 0.12);
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: 0 18px 34px rgba(2, 25, 39, 0.12);
        opacity: 0;
        pointer-events: none;
        transform: translateY(-8px);
        transition: opacity 180ms ease, transform 180ms ease;
      }
      .header-lang.is-open .header-lang-menu {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
        z-index: 1;
      }
      .header-lang-option {
        display: block;
        width: 100%;
        padding: 0.7rem 0.9rem;
        border-radius: 10px;
        font-family: Montserrat, sans-serif;
        font-size: 0.8125rem;
        font-weight: 700;
        letter-spacing: 0.14rem;
        text-transform: uppercase;
        color: #005776;
        text-align: left;
        transition: background-color 180ms ease, color 180ms ease;
      }
      .header-lang-option:hover,
      .header-lang-option.is-active {
        background: rgba(0, 124, 168, 0.08);
        color: #007ca8;
      }
      .header-search-overlay {
        position: fixed;
        inset: 0;
        z-index: 220;
        opacity: 0;
        pointer-events: none;
        transition: opacity 260ms ease;
      }
      .header-search-overlay.is-open {
        opacity: 1;
        pointer-events: auto;
      }
      .header-search-backdrop {
        position: absolute;
        inset: 0;
        background:
          radial-gradient(circle at top, rgba(0, 124, 168, 0.24), transparent 34%),
          rgba(1, 22, 33, 0.84);
        backdrop-filter: blur(22px);
        -webkit-backdrop-filter: blur(22px);
      }
      .header-search-panel {
        position: relative;
        z-index: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        min-height: 100%;
        max-width: 1040px;
        margin: 0 auto;
        padding: 2rem 2rem 3rem;
      }
      .header-search-close {
        position: absolute;
        top: 2rem;
        right: 2rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 62px;
        height: 62px;
        border: 1px solid rgba(255, 255, 255, 0.22);
        border-radius: 9999px;
        color: #f8fbfd;
        transition: background-color 180ms ease, border-color 180ms ease;
      }
      .header-search-close:hover {
        background: rgba(255, 255, 255, 0.08);
        border-color: rgba(255, 255, 255, 0.38);
      }
      .header-search-kicker {
        margin-bottom: 1rem;
        font-family: Montserrat, sans-serif;
        font-size: 0.875rem;
        font-weight: 700;
        letter-spacing: 0.22rem;
        text-transform: uppercase;
        color: rgba(248, 251, 253, 0.68);
      }
      .header-search-title {
        max-width: 42rem;
        margin: 0 0 2rem;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 48px;
        line-height: 1;
        color: #f8fbfd;
      }
      .header-search-form {
        display: flex;
        align-items: center;
        gap: 1rem;
        padding: 1.1rem 1.2rem 1.1rem 1.5rem;
        border: 1px solid rgba(255, 255, 255, 0.16);
        border-radius: 9999px;
        background: rgba(255, 255, 255, 0.08);
      }
      .header-search-input {
        flex: 1;
        min-width: 0;
        background: transparent;
        border: 0;
        color: #ffffff;
        font-family: Montserrat, sans-serif;
        font-size: clamp(1rem, 1.8vw, 1.3rem);
        line-height: 1.4;
      }
      .header-search-input::placeholder {
        color: rgba(255, 255, 255, 0.55);
      }
      .header-search-input:focus {
        outline: none;
      }
      .header-search-submit {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 58px;
        height: 58px;
        border-radius: 9999px;
        background: #007ca8;
        color: #ffffff;
        transition: transform 180ms ease, background-color 180ms ease;
      }
      .header-search-submit:hover {
        background: #005776;
        transform: translateY(-1px);
      }
      .header-search-suggestions {
        display: flex;
        flex-wrap: wrap;
        gap: 0.9rem;
        margin-top: 1.5rem;
      }
      .header-search-tag {
        display: inline-flex;
        align-items: center;
        padding: 0.72rem 1rem;
        border-radius: 9999px;
        background: rgba(255, 255, 255, 0.08);
        border: 1px solid rgba(255, 255, 255, 0.12);
        color: rgba(255, 255, 255, 0.8);
        font-family: Montserrat, sans-serif;
        font-size: 0.8rem;
        font-weight: 600;
        letter-spacing: 0.1rem;
        text-transform: uppercase;
      }
      .mobile-header-bar {
        display: none;
      }
      .mobile-header-nav {
        display: none;
      }
      .mobile-weather-strip {
        display: none;
      }
      @media (max-width: 1760px) {
        :root {
          --desktop-cta-width: 314px;
          --desktop-menu-width: 118px;
        }
        .desktop-header-top {
          padding-left: 2rem;
        }
        .desktop-header-bottom {
          padding-left: 1.5rem;
        }
        .desktop-header-shell .header-logo-cluster {
          gap: 0.95rem;
          transform: scale(0.96);
          transform-origin: left center;
        }
        .desktop-header-shell .weather-strip {
          gap: 0.45rem;
        }
        .desktop-nav-link {
          padding: 0 1rem;
          font-size: 0.8rem;
          letter-spacing: 0.145rem;
        }
        .desktop-header-bottom .header-phone-link {
          padding-left: 0.95rem;
          padding-right: 0.95rem;
          font-size: 0.82rem;
          letter-spacing: 0.145rem;
        }
        .desktop-header-shell .header-menu-trigger {
          padding-right: 1.7rem;
        }
        .hero-status-card {
          left: 30.5%;
        }
      }
      @media (max-width: 1590px) {
        :root {
          --desktop-cta-width: 286px;
          --desktop-menu-width: 98px;
        }
        .desktop-header-top {
          padding-left: 1.5rem;
        }
        .desktop-header-bottom {
          padding-left: 1.15rem;
        }
        .desktop-nav-link {
          padding: 0 0.78rem;
          font-size: 0.74rem;
          letter-spacing: 0.12rem;
        }
        .desktop-header-shell .header-logo-cluster {
          gap: 0.78rem;
          transform: scale(0.92);
          transform-origin: left center;
        }
        .desktop-header-shell .weather-strip {
          gap: 0.4rem;
        }
        .desktop-header-shell .weather-box {
          height: 60px !important;
          padding: 0 0.65rem !important;
        }

        .desktop-header-shell .weather-box span {
          font-size: 0.8rem;
          letter-spacing: 0.12rem;
        }
        .desktop-header-shell .header-lang-button {
          font-size: 0.9rem;
          letter-spacing: 0.06rem;
        }
        .desktop-header-shell .header-search-trigger {
          padding-left: 0.8rem;
          padding-right: 0.8rem;
        }
        .desktop-header-shell .header-menu-trigger {
          padding-right: 1.3rem;
        }
        .desktop-header-bottom .header-phone-link {
          padding-left: 0.82rem;
          padding-right: 0.82rem;
          font-size: 0.75rem;
          letter-spacing: 0.12rem;
        }
      }
      @media (max-width: 1365px) {
        :root {
          --desktop-cta-width: 286px;
          --desktop-menu-width: 92px;
        }
        .desktop-header-top {
          padding-left: 1.5rem;
        }
        .desktop-header-bottom {
          padding-left: 1.25rem;
          padding-right: 0;
        }
        .desktop-header-shell .header-logo-cluster {
          gap: 0.75rem;
          transform: scale(0.92);
          transform-origin: left center;
        }
        .desktop-header-shell .weather-strip {
          gap: 0.5rem;
          height: 85px;
        }
        .desktop-header-shell .weather-box {
          height: 58px !important;
          padding: 0 0.7rem !important;
        }
        .desktop-header-shell .weather-box img {
          width: 19px;
          height: 19px;
        }
        .desktop-header-shell .weather-box span {
          font-size: 0.84rem;
          letter-spacing: 0.14rem;
        }

        .desktop-header-shell .header-actions {
          gap: 0;
        }
        .desktop-header-shell .header-search-trigger {
          padding-left: 1rem;
          padding-right: 1rem;
        }
        .desktop-header-shell .header-lang-button {
          height: 85px;
          font-size: 0.88rem;
          letter-spacing: 0.08rem;
        }
        .desktop-header-shell .header-reserve-cta {
          padding-left: 1rem;
          padding-right: 1rem;
        }
        .desktop-header-shell .header-menu-trigger {
          padding-left: 1rem;
          padding-right: 1.1rem;
        }
        .desktop-header-shell .header-menu-trigger img {
          width: 30px;
          height: 22px;
        }
        .desktop-header-bottom .header-phone-link {
          padding-left: 1rem;
          padding-right: 1rem;
          font-size: 0.79rem;
          letter-spacing: 0.16rem;
        }
        .desktop-header-bottom .header-route-cta {
          padding-left: 1rem;
          padding-right: 1rem;
        }
        .header-phone-row {
          padding-right: calc(var(--desktop-cta-width) + var(--desktop-menu-width));
        }
        .hero-status-card {
          top: 0.25rem;
          left: 30%;
          width: 422px;
          grid-template-columns: 126px minmax(0, 1fr);
        }
        .hero-status-card > div {
          padding: 0.75rem 1rem 0.85rem;
        }
        .hero-status-label {
          margin-bottom: 0.45rem;
          font-size: 0.82rem;
        }
        .hero-status-value {
          font-size: 0.83rem;
          letter-spacing: 0.18rem;
        }
        .hero-status-value.hero-status-large {
          font-size: 0.74rem;
          letter-spacing: 0.15rem;
        }
      }
      @media (max-width: 1365px) {
        .brand-strip-inner {
          width: min(980px, calc(100% - 3rem));
          gap: 44px;
          min-height: 187px;
        }
        .brand-strip-title {
          font-size: 56px;
        }
        .home-intro-inner {
          width: min(1040px, calc(100% - 3rem));
        }
        .home-intro-title {
          max-width: 860px;
          font-size: 58px;
        }
        .infra-shell {
          width: min(1040px, calc(100% - 3rem));
        }
        .infra-accent {
          margin-bottom: 4.25rem;
        }
        .infra-title {
          max-width: 900px;
          font-size: 5rem;
        }
        .infra-grid {
          margin-top: 4.5rem;
          gap: 34px 24px;
        }
        .infra-decor-left,
        .infra-decor-right {
          opacity: 0.09;
          transform: scale(0.86);
        }
        .location-shell {
          width: min(1040px, calc(100% - 3rem));
        }
        .location-head,
        .location-separator,
        .location-features {
          width: calc(100% - 48px);
          padding-left: 0;
          padding-right: 0;
        }
        .location-title {
          font-size: 58px;
        }
        .reservation-shell {
          width: min(1120px, calc(100% - 3rem));
        }
        .reservation-form,
        .reservation-side {
          padding: 80px 48px;
        }
        .reservation-form-top {
          gap: 72px;
        }
        .ferry-section {
          grid-template-columns: minmax(0, 58.854vw) minmax(0, 1fr);
        }
        .ferry-visual {
          padding: 40px 18px 40px 140px;
        }
        .ferry-title-clip { font-size: 78px; line-height: 78px; }
        .ferry-title-subtitle { font-size: 52px; }
        .ferry-content-inner {
          width: 520px;
        }
        .vezovi-section {
          padding-left: 120px;
          padding-right: 120px;
        }
        .vezovi-title { font-size: 56px; }
        .vezovi-apps-title { font-size: 42px; }
      }
      @media (max-width: 1179px) {
        .home-hero {
          min-height: calc(100vh - var(--header-height-tablet));
          aspect-ratio: auto;
          background-position: center center;
        }
        .hero-status-card {
          left: 50%;
          top: 0.2rem;
          transform: translateX(-50%);
        }
        .hero-progress {
          left: 12%;
          right: 12%;
        }
        .desktop-header-top {
          padding-left: var(--page-gutter-tablet);
        }
        .desktop-header-bottom {
          padding-left: 2rem;
          padding-right: 2rem;
        }
        .desktop-header-shell .header-logo-cluster {
          transform: none;
        }
        .home-brand-strip {
          min-height: 187px;
        }
        .brand-strip-inner {
          width: calc(100% - 48px);
          gap: 40px;
        }
        .brand-strip-title {
          font-size: 56px;
        }
        .home-intro-section {
          min-height: 630px;
        }
        .home-intro-inner {
          width: calc(100% - 88px);
          padding-top: 50px;
        }
        .home-intro-title {
          max-width: 653px;
          font-size: 64px;
        }
        .home-intro-pattern {
          width: 504px;
          height: 647px;
        }
        .home-intro-watermark {
          right: -250px;
          bottom: -50px;
          width: 720px;
        }
        .infra-section {
          padding: 4rem 0 6rem;
        }
        .infra-shell {
          width: calc(100% - 48px);
        }
        .infra-accent {
          margin-bottom: 3.5rem;
        }
        .infra-title {
          max-width: 639px;
          font-size: 6rem;
        }
        .infra-grid {
          width: 100%;
          margin-top: 3.5rem;
          grid-template-columns: repeat(4, minmax(0, 178px));
          gap: 36px 35px;
          transform: scale(0.93);
          transform-origin: top center;
        }
        .infra-modal-close {
          top: -74px;
          right: -8px;
        }
        .infra-modal-title {
          font-size: 46px;
        }
        .infra-modal-desc {
          font-size: 17px;
        }
        .infra-decor-right {
          right: -90px;
          bottom: -12px;
          transform: scale(1.01);
          opacity: 0.1;
        }
        .infra-decor-left {
          top: -14px;
          left: -102px;
          transform: scale(0.98);
          opacity: 0.1;
        }
        .location-section {
          min-height: 900px;
        }
        .location-shell {
          width: calc(100% - 48px);
          min-height: 860px;
          padding-top: 64px;
        }
        .location-head {
          min-height: 320px;
        }
        .location-title {
          font-size: 54px;
        }
        .reservation-section {
          margin-top: -72px;
        }
        .reservation-section::before {
          inset: 72px 0 0;
        }
        .reservation-shell {
          width: calc(100% - 48px);
          min-height: auto;
        }
        .reservation-form,
        .reservation-side {
          padding: 58px 44px;
        }
        .reservation-form-top {
          gap: 56px;
        }
        .reservation-title {
          font-size: 44px;
        }
        .ferry-section {
          grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.88fr);
        }
        .ferry-visual {
          padding: 36px 18px 36px 100px;
        }
        .ferry-title-clip { font-size: 64px; line-height: 64px; }
        .ferry-title-subtitle { font-size: 42px; }
        .ferry-content-inner {
          max-width: calc(100% - 32px);
        }
        .ferry-copy {
          font-size: 12px;
          letter-spacing: 2.2px;
        }
        .ferry-actions {
          flex-direction: column;
          gap: 18px;
        }
        .ferry-ticket,
        .ferry-schedule {
          width: 100%;
          flex: none;
        }
        .vezovi-section {
          padding-left: 80px;
          padding-right: 80px;
        }
        .vezovi-title { font-size: 48px; }
        .vezovi-apps { align-items: stretch; gap: 28px; }
        .vezovi-apps-links { width: min(605px, 100%); }
        .experience-shell {
          width: calc(100% - 48px);
        }
        .experience-cards {
          gap: 18px;
          height: 620px;
        }
        .experience-card {
          flex-basis: 190px;
          width: 190px;
        }
        .experience-card-active {
          flex-basis: 0;
          width: auto;
        }
        .experience-card-active .experience-card-title {
          font-size: 74px;
          line-height: 76px;
        }
        #standardi,
        #aktuelnosti {
          padding-left: 48px !important;
          padding-right: 48px !important;
        }
        #standardi > div:nth-child(2),
        #standardi > div:nth-child(3) {
          width: 100% !important;
        }
        footer > div:first-child {
          padding-left: 48px !important;
          padding-right: 48px !important;
        }
      }
      @media (max-width: 1023px) {
        html,
        body {
          overflow-x: hidden;
        }
        .desktop-header-shell {
          display: none;
        }
        .mobile-header-bar {
          display: flex;
        }
        .mobile-weather-strip {
          display: flex;
        }
        .mobile-weather-strip .weather-box {
          padding: 0 10px;
        }
        .mobile-header-nav {
          display: flex;
          align-items: center;
          height: 50px;
          padding: 0 12px;
          overflow-x: auto;
          -webkit-overflow-scrolling: touch;
          scrollbar-width: none;
        }
        .mobile-header-nav::-webkit-scrollbar {
          display: none;
        }
        .mobile-header-nav .desktop-nav-link {
          height: 50px;
          padding: 0 12px;
          border-bottom-width: 4px;
          font-size: 0.8125rem;
          letter-spacing: 0.14rem;
        }
        .home-hero {
          min-height: 570px;
          aspect-ratio: auto;
          background-position: 63% center;
        }
        .hero-video {
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          /* +52px: video u sebi ima "zapečen" progress bar pri dnu – kropujemo ga */
          height: calc(100% + 52px);
          object-fit: cover;
        }
        .hero-status-card,
        .hero-progress {
          display: none;
        }
        .header-search-close {
          top: 1rem;
          right: 1rem;
          width: 52px;
          height: 52px;
        }
        .header-search-panel {
          padding: 6rem 1.25rem 2rem;
        }
        .header-search-form {
          padding: 0.85rem 0.9rem 0.85rem 1.1rem;
        }
        .header-search-submit {
          width: 50px;
          height: 50px;
        }
        .home-brand-strip {
          min-height: 187px;
        }
        .brand-strip-inner {
          width: calc(100% - 74px);
          gap: 64px;
          padding: 38px 0 32px;
          min-height: 187px;
        }
        .brand-strip-copy {
          gap: 34px;
        }
        .brand-strip-title {
          font-size: 48px;
        }
        .brand-strip-subtitle {
          font-size: 31px;
          font-weight: 300;
          line-height: 1.25;
        }
        .home-intro-section {
          min-height: 630px;
        }
        .home-intro-inner {
          width: calc(100% - 182px);
          padding-top: 40px;
        }
        .home-intro-title {
          max-width: 379px;
          font-size: 64px;
        }
        .home-intro-text {
          max-width: 379px;
          margin-top: 33px;
        }
        .home-intro-link {
          flex-wrap: wrap;
          margin-top: 33px;
        }
        .home-intro-small-image {
          display: none;
        }
        .home-intro-watermark {
          right: -300px;
          bottom: 40px;
          width: 700px;
        }
        .infra-section {
          padding: 3rem 0 4.5rem;
        }
        .infra-shell {
          width: calc(100% - 30px);
        }
        .infra-accent {
          margin-bottom: 2rem;
        }
        .infra-title {
          max-width: 382px;
          font-size: 3rem;
          line-height: 1;
        }
        .infra-grid {
          width: 100%;
          margin-top: 2.75rem;
          transform: none;
          grid-template-columns: repeat(4, minmax(0, 1fr));
          gap: 32px 24px;
        }
        .infra-card {
          min-height: 139px;
        }
        .infra-icon-wrap {
          margin-bottom: 24px;
        }
        .infra-card-title {
          font-size: 18px;
        }
        .infra-modal-dialog {
          width: min(calc(100vw - 32px), 328px);
          padding: 30px 22px 28px;
          border-radius: 26px;
        }
        .infra-modal-close {
          top: -62px;
          right: 0;
          width: 50px;
          height: 50px;
        }
        .infra-modal-icon {
          width: 92px;
          height: 92px;
          background-size: 46px 46px;
          margin-bottom: 24px;
        }
        .infra-modal-title {
          font-size: 36px;
        }
        .infra-modal-divider {
          width: 34px;
          margin-bottom: 22px;
        }
        .infra-modal-desc {
          font-size: 15px;
          line-height: 1.56;
        }
        .infra-decor-left,
        .infra-decor-right {
          opacity: 0.08;
        }
        .infra-decor-left {
          top: auto;
          bottom: -34px;
          left: -170px;
          transform: scale(0.72);
        }
        .infra-decor-right {
          right: -180px;
          bottom: 100px;
          transform: scale(0.68);
        }
        .location-section {
          min-height: 980px;
          background-position: 58% center;
        }
        .location-shell {
          width: calc(100% - 48px);
          min-height: 920px;
          padding-top: 48px;
        }
        .location-head {
          display: block;
          width: 100%;
          min-height: auto;
          padding: 0;
        }
        .location-copy {
          max-width: 399px;
        }
        .location-title {
          font-size: 32px;
          line-height: 1.5;
        }
        .location-cta {
          margin-top: 50px;
        }
        .location-separator {
          width: 100%;
          margin-top: 36px;
        }
        .location-features {
          width: 100%;
          margin-top: 36px;
          gap: 15px;
        }
        .location-feature {
          min-height: 130px;
          align-items: flex-start;
        }
        .location-feature-copy {
          max-width: calc(100% - 72px);
        }
        .location-feature-title {
          font-size: 32px;
        }
        .reservation-section {
          padding-bottom: 48px;
          margin-top: -60px;
        }
        .reservation-section::before {
          inset: 60px 0 0;
        }
        .reservation-shell {
          grid-template-columns: 1fr;
          width: calc(100% - 48px);
          border-radius: 8px;
        }
        .reservation-form,
        .reservation-side {
          padding: 44px 28px;
        }
        .reservation-form-top {
          gap: 40px;
        }
        .reservation-side {
          align-self: auto;
        }
        .reservation-title {
          font-size: 44px;
        }
        .reservation-side-title {
          font-size: 38px;
        }
        .ferry-section {
          display: block;
          padding: 0 0 42px;
        }
        .ferry-visual {
          width: 100%;
          aspect-ratio: 1130 / 325;
          padding: 24px 24px 24px 40px;
        }
        .ferry-title-clip { font-size: 48px; line-height: 48px; }
        .ferry-title-subtitle { font-size: 32px; }
        .ferry-content {
          min-height: auto;
          padding: 34px 24px 0;
        }
        .ferry-content-inner {
          width: 100%;
          max-width: none;
          gap: 34px;
        }
        .ferry-actions {
          flex-direction: row;
          gap: 16px;
        }
        .ferry-ticket,
        .ferry-schedule {
          flex: 1 0 0;
          width: auto;
        }
        .vezovi-section {
          padding: 56px 48px 80px;
        }
        .vezovi-title { font-size: 42px; }
        .vezovi-grid {
          grid-template-columns: 1fr;
          gap: 28px;
        }
        .vezovi-card-komerc,
        .vezovi-card-komu {
          padding: 36px 28px;
        }
        .vezovi-card-title { font-size: 38px; }
        .vezovi-count { font-size: 52px; }
        .vezovi-apps {
          flex-direction: column;
          align-items: stretch;
          padding: 32px 28px 40px;
        }
        .vezovi-apps-links {
          width: 100%;
          padding-left: 0;
          border-left: none;
          border-top: 1px solid #abb0ba;
          padding-top: 24px;
          flex-wrap: wrap;
        }
        .vezovi-app-item--walkdock,
        .vezovi-app-item--weather { width: 254px; }
        .vezovi-apps-title { font-size: 36px; }
        .experience-section {
          padding: 64px 0 76px;
          background: #02394c;
        }
        .experience-wave {
          display: none;
        }
        .experience-title {
          font-size: 72px;
          line-height: 72px;
          color: #ffffff;
        }
        .experience-cards {
          display: flex;
          height: 520px;
          gap: 16px;
          overflow-x: auto;
          -webkit-overflow-scrolling: touch;
          scrollbar-width: none;
        }
        .experience-cards::-webkit-scrollbar {
          display: none;
        }
        .experience-card {
          flex: 0 0 290px;
          width: 290px;
        }
        .experience-card-active {
          flex: 0 0 306px;
          width: 306px;
        }
        #standardi,
        #aktuelnosti {
          padding-left: 24px !important;
          padding-right: 24px !important;
        }
        #standardi h2,
        #aktuelnosti h2 {
          font-size: 48px !important;
        }
        #standardi > div:nth-child(2) {
          display: grid !important;
          grid-template-columns: repeat(2, minmax(0, 1fr));
          gap: 18px !important;
        }
        #standardi > div:nth-child(2) > div {
          width: 100% !important;
        }
        #standardi > div:nth-child(3) {
          padding-left: 32px !important;
          padding-right: 32px !important;
        }
        #standardi > div:nth-child(3) h3 {
          font-size: 40px !important;
        }
        #standardi > div:nth-child(3) p[class*="text-[96px]"] {
          font-size: 68px !important;
          line-height: 72px !important;
        }
      }
      @media (max-width: 429px) {
        .mobile-header-bar {
          padding-left: 16px;
          padding-right: 12px;
        }
        .mobile-header-bar .mobile-logo-cluster,
        .mobile-header-bar .mobile-logo-cluster > a {
          gap: 8px;
        }
        .mobile-header-bar .mobile-logo-divider {
          margin-left: 0;
          margin-right: 0;
        }
        .mobile-header-bar .mobile-logo-letters {
          width: 118px;
          height: 16px;
        }
        .mobile-header-bar .mobile-logo-secondary {
          width: 78px;
          height: 34px;
        }
        .mobile-header-bar button#menu-open-mobile {
          width: 44px;
          height: 44px;
        }
      }
      @media (max-width: 349px) {
        .mobile-header-bar .mobile-logo-divider,
        .mobile-header-bar .mobile-logo-secondary {
          display: none;
        }
      }
      @media (max-width: 639px) {
        .mobile-weather-strip {
          display: none;
        }
        .mobile-header-nav {
          display: none;
        }
        .home-hero {
          min-height: 376px;
          background-position: 66% center;
        }
        .home-brand-strip {
          min-height: 0;
        }
        .brand-strip-inner {
          flex-direction: column;
          width: calc(100% - 72px);
          gap: 14px;
          padding: 32px 0;
          min-height: 0;
        }
        .brand-strip-copy {
          gap: 24px;
        }
        .brand-strip-title {
          font-size: 32px;
        }
        .brand-strip-subtitle {
          font-size: 16px;
          font-weight: 400;
        }
        .home-intro-section {
          min-height: 830px;
        }
        .home-intro-inner {
          width: calc(100% - 48px);
          padding-top: 24px;
        }
        .home-intro-pattern {
          width: 427px;
          height: 647px;
        }
        .home-intro-title {
          font-size: 52px;
        }
        .home-intro-play {
          width: 90px;
          height: 90px;
        }
        .home-intro-line {
          width: 72px;
        }
        .reservation-section {
          margin-top: -40px;
        }
        .reservation-section::before {
          inset: 40px 0 0;
        }
        .reservation-shell {
          width: calc(100% - 32px);
          border-radius: 6px;
        }
        .reservation-form,
        .reservation-side {
          padding: 38px 22px;
        }
        .reservation-form-top {
          gap: 32px;
        }
        .reservation-title {
          font-size: 38px;
        }
        .reservation-side-title {
          font-size: 34px;
        }
        .ferry-visual {
          aspect-ratio: auto;
          min-height: 426px;
          padding: 20px 16px 20px 24px;
          align-content: end;
        }
        .ferry-title-clip { font-size: 44px; line-height: 46px; }
        .ferry-title-subtitle { font-size: 28px; }
        .ferry-content {
          padding-left: 16px;
          padding-right: 16px;
        }
        .ferry-copy {
          font-size: 11px;
          letter-spacing: 1.8px;
        }
        .ferry-actions {
          flex-direction: column;
        }
        .ferry-ticket,
        .ferry-schedule {
          width: 100%;
          flex: none;
        }
        .vezovi-section {
          padding: 48px 16px 64px;
        }
        .vezovi-title { font-size: 36px; }
        .vezovi-card-komerc,
        .vezovi-card-komu {
          padding: 32px 22px;
        }
        .vezovi-card-title { font-size: 32px; }
        .vezovi-count { font-size: 44px; }
        .vezovi-bars { gap: 16px; }
        .vezovi-apps {
          border-radius: 18px;
          padding: 28px 20px 34px;
        }
        .vezovi-apps-title { font-size: 34px; }
        .vezovi-app-item--walkdock,
        .vezovi-app-item--weather { width: 100%; }
        .experience-shell {
          width: calc(100% - 32px);
        }
        .experience-title {
          font-size: 48px;
          line-height: 52px;
        }
        .experience-cards {
          display: flex;
          flex-direction: column;
          height: auto;
          gap: 12px;
          overflow: visible;
        }
        .experience-card,
        .experience-card-active {
          width: 100%;
          flex: initial;
          min-height: 0;
          height: 124px;
        }
        .experience-card-active {
          height: 420px;
        }
        .experience-card .experience-card-copy {
          display: none;
        }
        .experience-card-active .experience-card-copy {
          display: block;
        }
        .experience-card-active .experience-card-title {
          font-size: 54px;
          line-height: 56px;
        }
        .experience-card-active .experience-card-top {
          display: block;
        }
        .experience-tags {
          margin-bottom: 20px;
        }
        .experience-pagination {
          width: 100%;
        }
        .experience-pagination-bar {
          grid-template-columns: 26% 26% 48%;
        }
        #standardi,
        #aktuelnosti {
          padding: 56px 16px !important;
        }
        #standardi h2,
        #aktuelnosti h2 {
          font-size: 40px !important;
        }
        #standardi > div:nth-child(2) {
          grid-template-columns: 1fr;
        }
        #standardi > div:nth-child(3) {
          padding: 30px 20px !important;
        }
        #standardi > div:nth-child(3) h3 {
          font-size: 32px !important;
        }
        #standardi > div:nth-child(3) > div > div:last-child {
          display: grid !important;
          grid-template-columns: 1fr;
          gap: 28px !important;
        }
        #aktuelnosti > div:last-child {
          grid-template-columns: 1fr !important;
        }
        footer > div:first-child {
          padding-left: 24px !important;
          padding-right: 24px !important;
        }
        footer form {
          width: 100% !important;
        }
        footer .bg-black > div {
          flex-direction: column;
          align-items: flex-start;
          gap: 20px;
        }
        .infra-shell {
          width: calc(100% - 32px);
        }
        .infra-title {
          width: 100%;
        }
        .infra-grid {
          grid-template-columns: repeat(2, minmax(0, 1fr));
          gap: 34px 18px;
        }
        .infra-card-title {
          font-size: 1.5rem;
        }
      }
      @media (max-width: 1365px) {
        .service-community-inner {
          width: calc(100% - 96px);
          gap: 48px;
        }
        .service-community-content {
          padding-left: 0;
        }
        .local-services-section::before {
          left: 48px;
        }
        .local-services-section::after {
          right: -130px;
        }
        .local-services-intro,
        .local-services-outro,
        .local-services-list {
          width: calc(100% - 260px);
        }
        .local-service-row {
          grid-template-columns: 88px 78px minmax(0, 1fr) 260px;
          gap: 30px;
        }
        .local-service-thumb {
          width: 260px;
        }
      }
      @media (max-width: 1023px) {
        .service-community-section {
          padding-top: 72px;
        }
        .service-community-title {
          margin-bottom: 40px;
        }
        .service-community-inner {
          grid-template-columns: 1fr;
          width: calc(100% - 48px);
          padding: 112px 0 70px;
        }
        .service-community-image {
          height: 280px;
        }
        .office-hours-strip {
          min-height: 44px;
          padding: 0 24px;
        }
        .office-hours-strip p {
          text-align: center;
          line-height: 1.35;
        }
        .local-services-section {
          padding: 54px 0 72px;
        }
        .local-services-section::before {
          left: -110px;
          opacity: 0.06;
        }
        .local-services-section::after {
          right: -210px;
          opacity: 0.12;
        }
        .local-services-intro,
        .local-services-outro,
        .local-services-list {
          width: calc(100% - 48px);
        }
        .local-services-intro {
          margin-bottom: 28px;
        }
        .local-services-outro {
          margin-top: 28px;
        }
        .local-services-title {
          margin-bottom: 14px;
          font-size: 38px;
        }
        .local-service-row {
          grid-template-columns: 74px 74px minmax(0, 1fr);
          gap: 22px;
          padding: 28px 0;
        }
        .local-service-thumb {
          grid-column: 3;
          width: 100%;
          height: 180px;
        }
      }
      @media (max-width: 639px) {
        .service-community-title {
          font-size: 38px;
        }
        .service-community-panel::before {
          top: -78px;
          height: 160px;
          border-bottom-width: 5px;
            display: none;
        }
        .service-community-inner {
          width: calc(100% - 32px);
          padding-top: 88px;
        }
        .service-community-heading {
          font-size: 38px;
          line-height: 0.95;
        }
        .service-community-actions {
          display: grid;
          gap: 18px;
        }
        .service-community-cta,
        .service-community-link {
          width: 100%;
          justify-content: center;
          text-align: center;
        }
        .service-community-cta {
          min-width: 0;
        }
        .service-community-image {
          height: 220px;
        }
        .office-hours-strip p {
          font-size: 11px;
          letter-spacing: 1.4px;
        }
        .local-services-intro,
        .local-services-outro,
        .local-services-list {
          width: calc(100% - 32px);
        }
        .local-services-title {
          font-size: 32px;
        }
        .local-services-text {
          font-size: 15px;
          line-height: 23px;
        }
        .local-service-row {
          grid-template-columns: 70px 1fr;
          gap: 16px;
          min-height: 0;
        }
        .local-service-number {
          font-size: 48px;
        }
        .local-service-icon {
          justify-content: flex-start;
          width: 58px;
          height: 58px;
        }
        .local-service-copy {
          grid-column: 1 / -1;
        }
        .local-service-copy h3 {
          font-size: 38px;
        }
        .local-service-thumb {
          grid-column: 1 / -1;
          height: 190px;
        }
      }
      .section-accent {
        display: block;
        width: 30px;
        height: 4px;
        background: #005776;
      }
      .section-accent.is-light {
        background: rgba(255, 255, 255, 0.9);
      }
      .standards-section,
      .news-section,
      .team-section,
      .signature-section {
        position: relative;
        overflow: hidden;
        background: #ffffff;
      }
      .standards-shell,
      .news-shell,
      .team-shell,
      .signature-shell {
        width: min(1248px, calc(100% - 142px));
        margin: 0 auto;
      }
      /* Wide shell: for section headers that extend beyond the content width */
      .wide-shell {
        width: min(1503px, calc(100% - 80px));
        margin: 0 auto;
      }
      .standards-section {
        padding: 96px 0;
        background: #ffffff;
      }
      .standards-shell {
        display: flex;
        flex-direction: column;
        gap: 64px;
      }
      .standards-accent {
        display: block;
        width: 30px;
        height: 4px;
        background: #005776;
        flex-shrink: 0;
      }
      .standards-header {
        display: flex;
        flex-direction: column;
        gap: 22px;
      }
      .standards-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        font-weight: 400;
        line-height: 1;
        color: #859da6;
      }
      .standards-subtitle {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 26px;
        color: #54595f;
      }
      .standards-cards {
        display: flex;
        justify-content: space-between;
        gap: 24px;
        padding-left: 24px;
      }
      .standards-card {
        width: 288px;
        flex-shrink: 0;
        background: #fafbfb;
        border-radius: 10px;
        padding: 24px;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 16px;
      }
      .standards-card-circle {
        width: 80px;
        height: 80px;
        border-radius: 50%;
        background: #005776;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
      }
      .standards-card-title {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 2.8px;
        text-transform: uppercase;
        color: #0068ac;
        line-height: 1.3;
      }
      .standards-card-desc {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 26px;
        color: #54595f;
      }
      .standards-trust-box {
        background: #02394c;
        border-radius: 10px;
        padding: 36px 96px;
        margin-left: 24px;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 16px;
      }
      .standards-trust-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 48px;
        font-weight: 400;
        line-height: 1.1;
        color: #ffffff;
        text-align: center;
      }
      .standards-trust-sub {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 26px;
        color: rgba(255, 255, 255, 0.9);
        text-align: center;
        max-width: 760px;
      }
      .standards-stats {
        display: flex;
        justify-content: center;
        gap: 80px;
        margin-top: 20px;
      }
      .standards-stat {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 8px;
      }
      .standards-stat-value {
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 96px;
        font-weight: 400;
        line-height: 96px;
        color: #f5f5f5;
      }
      .standards-stat-label {
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 1.4;
        color: rgba(255, 255, 255, 0.8);
        text-align: center;
      }
      /* shared header styles for other sections */
      .team-header {
        display: grid;
        gap: 24px;
      }
      .team-header h2,
      .signature-content h2 {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: clamp(44px, 3.8vw, 64px);
        font-weight: 400;
        line-height: 0.98;
        letter-spacing: -0.02em;
        color: #859da6;
      }
      .team-header p,
      .signature-content p {
        max-width: 760px;
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 26px;
        color: #54595f;
      }
      .news-section {
        padding: 96px 0 112px;
        background: #f5f5f5;
      }
      .news-shell {
        display: flex;
        flex-direction: column;
        gap: 62px;
      }
      .news-accent {
        display: block;
        width: 30px;
        height: 4px;
        background: #005776;
        flex-shrink: 0;
      }
      .news-header {
        display: flex;
        flex-direction: column;
        gap: 22px;
      }
      .news-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        font-weight: 400;
        line-height: 1;
        color: #859da6;
      }
      .news-subtitle {
        margin: 0;
        font-family: Montserrat, sans-serif;
        font-size: 16px;
        line-height: 24px;
        color: #54595f;
      }
      .news-grid {
        display: flex;
        justify-content: space-between;
        gap: 32px;
        padding-left: 24px;
      }
      /* ── Card ── */
      .news-card {
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 367px;
        flex-shrink: 0;
        background: #ffffff;
      }
      .news-card-img-wrap {
        width: 100%;
        aspect-ratio: 367 / 259;
        position: relative;
        z-index: 1;
        margin-bottom: -50px;
        overflow: hidden;
        background: #c4c4c4;
      }
      .news-card-img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 300ms ease;
      }
      .news-card:hover .news-card-img {
        transform: scale(1.04);
      }
      /* ── Inner (310px centred, above image so date badge is visible) ── */
      .news-card-inner {
        width: 310px;
        display: flex;
        flex-direction: column;
        gap: 10px;
        position: relative;
        z-index: 2;
      }
      /* ── Date badge + meta bar row ── */
      .news-card-metarow {
        display: flex;
        align-items: flex-start;
      }
      .news-card-date {
        width: 70px;
        height: 70px;
        background: #02394c;
        flex-shrink: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 6px;
      }
      .news-card-day {
        font-family: "Playfair Display", Georgia, serif;
        font-size: 30px;
        font-weight: 600;
        color: #ffffff;
        line-height: 1;
      }
      .news-card-month {
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 600;
        color: #ffffff;
        line-height: 1;
      }
      .news-card-info {
        flex: 1;
        height: 56px;
        background: #f5f5f5;
        display: flex;
        align-items: center;
        gap: 14px;
        padding: 0 24px 0 30px;
        margin-top: 14px; /* date=70, info=56, diff=14px → bottom-aligned */
      }
      .news-card-author,
      .news-card-comments {
        font-family: Poppins, sans-serif;
        font-size: 12px;
        font-weight: 400;
        color: #97b1ba;
        white-space: nowrap;
      }
      .news-card-dot {
        width: 4px;
        height: 4px;
        border-radius: 50%;
        background: #97b1ba;
        flex-shrink: 0;
      }
      /* ── Content: title + link ── */
      .news-card-content {
        display: flex;
        flex-direction: column;
        gap: 25px;
        padding: 12px 24px 36px;
      }
      .news-card-title {
        margin: 0;
        font-family: "Playfair Display", Georgia, serif;
        font-size: 20px;
        font-weight: 700;
        line-height: 1.4;
        color: #000000;
      }
      .news-card-title a {
        color: inherit;
        text-decoration: none;
      }
      .news-card-title a:hover {
        color: #005776;
      }
      .news-card-link {
        display: inline-block;
        font-family: Manrope, sans-serif;
        font-size: 12px;
        font-weight: 600;
        color: #02394c;
        letter-spacing: 2.4px;
        text-decoration: none;
      }
      .news-card-link:hover {
        color: #005776;
      }
      .team-section {
        padding: 96px 0 112px;
        background: #f5f5f5;
        position: relative;
        overflow: hidden;
      }
      .team-shell {
        display: flex;
        flex-direction: column;
        gap: 56px;
      }
      .team-accent {
        display: block;
        width: 30px;
        height: 4px;
        background: #005776;
        flex-shrink: 0;
      }
      .team-header {
        display: flex;
        flex-direction: column;
        gap: 22px;
      }
      .team-title {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 64px;
        font-weight: 400;
        line-height: 1;
        color: #859da6;
      }
      .team-members {
        display: flex;
        gap: 48px;
        justify-content: center;
        padding-left: 24px;
      }
      .team-card {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 18px;
        width: 270px;
        flex-shrink: 0;
      }
      .team-card-frame {
        width: 270px;
        height: 340px;
        border: 1px solid #87d0f5;
        position: relative;
        flex-shrink: 0;
      }
      .team-card-photo {
        position: absolute;
        top: 20px;
        left: 20px;
        width: 230px;
        height: 300px;
        overflow: hidden;
      }
      .team-card-photo img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
      }
      .team-card-info {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 5px;
      }
      .team-card-name {
        margin: 0;
        font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
        font-size: 24px;
        font-weight: 400;
        line-height: 1.2;
        color: #000000;
        text-align: center;
      }
      .team-card-role {
        margin: 0;
        font-family: Poppins, sans-serif;
        font-size: 14px;
        font-weight: 400;
        line-height: 1.4;
        color: #54595f;
        text-align: center;
      }
      /* Decorative elements */
      .team-decor {
        position: absolute;
        pointer-events: none;
        user-select: none;
      }
      .team-decor--left {
        left: 44px;
        top: 59px;
        width: 251px;
        height: 456px;
        object-fit: contain;
      }
      .team-decor--top-right {
        right: calc(1920px - 1878px);
        top: -217px;
        width: 356px;
        height: 364px;
        object-fit: contain;
        opacity: 0.12;
      }
      .team-decor--bot-right {
        right: calc(1920px - 1920px);
        top: 456px;
        width: 391px;
        height: 420px;
        object-fit: contain;
        transform: scaleY(-1) rotate(-0.1deg);
        opacity: 0.12;
      }
      .signature-section {
        padding: 116px 0 128px;
        background: #ffffff;
      }
      .signature-shell {
        display: grid;
        grid-template-columns: minmax(0, 0.9fr) 237px;
        gap: 66px;
        align-items: center;
      }
      .signature-content {
        display: grid;
        gap: 24px;
      }
      .signature-logo {
        width: 104px;
        height: 46px;
      }
      .signature-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 18px;
        margin-top: 10px;
      }
      .signature-primary,
      .signature-secondary {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 55px;
        padding: 0 28px;
        text-decoration: none;
        font-family: Montserrat, sans-serif;
        font-size: 12px;
        font-weight: 700;
        letter-spacing: 0.24em;
        text-transform: uppercase;
      }
      .signature-primary {
        background: #005776;
        color: #ffffff;
      }
      .signature-secondary {
        border: 1px solid rgba(0, 87, 118, 0.18);
        color: #005776;
      }
      .signature-visual {
        justify-self: end;
        width: 237px;
        border-radius: 30px;
        overflow: hidden;
      }
      .signature-visual img {
        display: block;
        width: 100%;
        height: 670px;
        object-fit: cover;
      }
      .signature-banner {
        width: min(1248px, calc(100% - 142px));
        margin: 52px auto 0;
        border-radius: 26px;
        overflow: hidden;
        box-shadow: 0 18px 42px rgba(8, 33, 45, 0.08);
      }
      .signature-banner img {
        display: block;
        width: 100%;
        height: auto;
      }
      @media (max-width: 1365px) {
        .wide-shell {
          width: calc(100% - 64px);
        }
        .standards-shell,
        .news-shell,
        .team-shell,
        .signature-shell,
        .signature-banner {
          width: calc(100% - 96px);
        }
        .standards-cards {
          flex-wrap: wrap;
          justify-content: center;
        }
        .team-members {
          flex-wrap: wrap;
          justify-content: center;
        }
        .news-grid {
          flex-wrap: wrap;
          justify-content: center;
          gap: 24px;
        }
        .signature-shell {
          grid-template-columns: minmax(0, 1fr) 220px;
          gap: 42px;
        }
      }
      @media (max-width: 1023px) {
        .standards-section,
        .news-section,
        .team-section,
        .signature-section {
          padding: 84px 0;
        }
        .wide-shell {
          width: calc(100% - 48px);
        }
        .standards-shell,
        .news-shell,
        .team-shell,
        .signature-shell,
        .signature-banner {
          width: calc(100% - 48px);
        }
        .signature-shell {
          grid-template-columns: 1fr;
        }
        .standards-trust-box {
          padding: 36px 32px;
        }
        .standards-stats {
          gap: 40px;
        }
        .news-card {
          width: 100%;
          max-width: 367px;
        }
        .signature-visual {
          justify-self: start;
          width: min(237px, 100%);
        }
        .signature-visual img {
          height: 520px;
        }
      }
      @media (max-width: 639px) {
        .wide-shell {
          width: calc(100% - 32px);
        }
        .standards-shell,
        .news-shell,
        .team-shell,
        .signature-shell,
        .signature-banner {
          width: calc(100% - 32px);
        }
        .standards-card {
          padding-left: 22px;
          padding-right: 22px;
        }
        .standards-stats {
          flex-direction: column;
          gap: 24px;
        }
        .news-card h3,
        .news-card h3 a {
          font-size: 30px;
        }
        .team-decor {
          display: none;
        }
        .signature-actions {
          display: grid;
        }
        .signature-primary,
        .signature-secondary {
          width: 100%;
        }
        .signature-visual {
          width: 100%;
        }
        .signature-visual img {
          height: 420px;
        }
      }

/* ══════════════════════════════════════════════════════
   STANJE U LUCI  –  Figma node 1138:918
   ══════════════════════════════════════════════════════ */
.stanje-section {
  background: #f5f5f5;
  padding: 96px 214px 80px;
}
.stanje-inner {
  display: flex;
  flex-direction: column;
  gap: 48px;
    width: min(1388px, calc(100% - 4rem));
    margin: 0 auto;
}
/* header */
.stanje-header { display: flex; flex-direction: column; gap: 19px; }
.stanje-accent { width: 30px; height: 4px; background: #005776; flex-shrink: 0; }
.stanje-title {
  font-family: "Ariata Display", "Cormorant Garamond", Georgia, serif;
  font-size: 64px; line-height: 1; color: #859da6; margin: 0;
}
.stanje-subtitle {
  font-family: Poppins, sans-serif;
  font-size: 16px; line-height: 24px; color: #abb0ba; margin: 0; max-width: 700px;
}
/* weather cards */
.stanje-cards {
  display: grid;
  grid-template-columns: minmax(0,1fr) 354px 355px minmax(0,1fr);
  gap: 33px;
  height: 190px;
}
.stanje-card {
  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(10.7px);
  -webkit-backdrop-filter: blur(10.7px);
  border: 2px solid #fafbfb;
  border-radius: 10px;
  box-shadow: 0px 23px 45px 0px rgba(0,0,0,0.25);
  padding: 31px;
  display: flex;
  flex-direction: column;
}
.stanje-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 54px;
  margin-bottom: 24px;
}
.stanje-card-icon { width: 48px; height: 48px; display: block; flex-shrink: 0; }
.stanje-card-value {
  font-family: Manrope, sans-serif; font-size: 42px;
  font-weight: 400; color: #97b1ba; white-space: nowrap;
}
.stanje-card-value--green {
  font-family: Poppins, sans-serif; font-size: 36px;
  font-weight: 700; line-height: 54px; color: #05df72;
}
.stanje-card-label {
  font-family: Poppins, sans-serif; font-size: 15px;
  font-weight: 600; line-height: 22.5px; color: #696d73; margin: 0 0 3px;
}
.stanje-card-status {
  font-family: Poppins, sans-serif; font-size: 13px;
  line-height: 19.5px; color: #97b1ba; margin: 0;
}
/* notifications */
.stanje-notices {
  background: white; border-radius: 12px;
  padding: 40px; display: flex; flex-direction: column; gap: 32px;
}
.stanje-notices-title {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 28px; font-weight: 600; line-height: 42px; color: #005776; margin: 0;
}
.stanje-notice-list { display: flex; flex-direction: column; gap: 20px; }
.stanje-notice {
  border-radius: 10px; padding: 36px 24px;
  display: flex; align-items: flex-start; gap: 16px;
}
.stanje-notice--info    { background: #eff6ff; }
.stanje-notice--success { background: #f0fdf4; }
.stanje-notice--neutral { background: #f9fafb; }
.stanje-notice-icon { width: 24px; height: 24px; flex-shrink: 0; margin-top: 1px; }
.stanje-notice-body { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.stanje-notice-title {
  font-family: Montserrat, sans-serif; font-size: 14px; font-weight: 700;
  letter-spacing: 1.4px; text-transform: uppercase; color: #005776; margin: 0;
}
.stanje-notice-text {
  font-family: Montserrat, sans-serif; font-size: 16px;
  line-height: 24px; color: #7c8087; margin: 0;
}
.stanje-notice-date {
  font-family: Manrope, sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 2.4px; color: #abb0ba; margin: 0;
}
/* footnote */
.stanje-footnote {
  font-family: Poppins, sans-serif; font-size: 13px;
  line-height: 19.5px; color: #abb0ba; text-align: center; margin: 0;
}
/* map + panel row */
.stanje-maprow {
  display: flex; height: 616px;
  border-radius: 16px; overflow: hidden;
    gap: 10px;
}
.stanje-map {
  position: relative; flex: 1; overflow: hidden;
  border-radius: 16px 0 0 16px;
}
.stanje-map-img {
  display: block;  width: 100%;
}
/* status panel */
.stanje-panel {
  width: 384px; flex-shrink: 0; background: white;
  border-left: 1px solid #e5e7eb; border-radius: 0 12px 12px 0;
  overflow: hidden; display: flex; flex-direction: column;
}
.stanje-panel-head {
  background: #02394c; padding: 24px;
  display: flex; align-items: center; gap: 12px;
  min-height: 108px; flex-shrink: 0;
}
.stanje-panel-ship { width: 32px; height: 32px; flex-shrink: 0; }
.stanje-panel-head-title {
  font-family: Montserrat, sans-serif; font-size: 14px; font-weight: 700;
  letter-spacing: 2.8px; text-transform: uppercase; color: white; margin: 0 0 4px;
}
.stanje-panel-head-sub {
  font-family: Montserrat, sans-serif; font-size: 14px;
  line-height: 20px; color: #dbeafe; margin: 0;
}
.stanje-panel-body {
  padding: 24px; overflow-y: auto; flex: 1;
  display: flex; flex-direction: column; gap: 24px;
}
.stanje-panel-section { display: flex; flex-direction: column; gap: 16px; }
.stanje-panel-section-head {
  display: flex; align-items: center; gap: 12px; padding: 4px 0;
}
.stanje-panel-section-icon { width: 20px; height: 20px; flex-shrink: 0; }
.stanje-panel-section-title {
  font-family: Montserrat, sans-serif; font-size: 14px; font-weight: 700;
  letter-spacing: 2.8px; text-transform: uppercase; color: #005776; margin: 0;
}
/* data table */
.stanje-data-table {
  background: #eff6ff; border-radius: 10px;
  padding: 16px; display: flex; flex-direction: column; gap: 12px;
}
.stanje-data-row {
  display: flex; align-items: center;
  justify-content: space-between; height: 24px;
}
.stanje-data-label {
  font-family: Montserrat, sans-serif; font-size: 11px; font-weight: 500;
  letter-spacing: 0.77px; color: #364153;
  text-transform: capitalize; display: flex; align-items: center; gap: 8px;
}
.stanje-data-icon { width: 16px; height: 16px; display: block; }
.stanje-data-value {
  font-family: Inter, sans-serif; font-size: 16px; font-weight: 600;
  line-height: 24px; letter-spacing: -0.31px; color: #005776;
}
.stanje-data-divider {
  border-top: 1px solid #abb0ba; padding-top: 9px;
  font-family: Manrope, sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 2.4px; color: #7c8087; line-height: 1;
}
/* service items */
.stanje-service-list { display: flex; flex-direction: column; gap: 12px; }
.stanje-service-item {
  background: white; border: 1px solid #e5e7eb; border-radius: 10px;
  padding: 17px; display: flex; align-items: flex-start; gap: 12px;
}
.stanje-service-icon-wrap {
  width: 36px; height: 36px; background: #a6e1ff; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.stanje-service-icon { width: 20px; height: 20px; display: block; }
.stanje-service-name {
  font-family: Inter, sans-serif; font-size: 16px; font-weight: 600;
  line-height: 24px; letter-spacing: -0.31px; color: #101828; margin: 0;
}
.stanje-service-desc {
  font-family: Inter, sans-serif; font-size: 14px;
  line-height: 20px; letter-spacing: -0.15px; color: #4a5565; margin: 2px 0 0;
}
/* additional features */
.stanje-features-box {
  background: linear-gradient(151.222deg, #eff6ff 0%, #dbeafe 100%);
  border-radius: 10px; padding: 16px; display: flex; flex-direction: column; gap: 8px;
}
.stanje-feature-item {
  display: flex; align-items: center; gap: 8px; height: 24px;
}
.stanje-feature-icon { width: 16px; height: 16px; flex-shrink: 0; }
.stanje-feature-text {
  font-family: Manrope, sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 2.4px; color: #364153;
}
/* contact box */
.stanje-contact-box {
  background: #005776; border-radius: 10px;
  padding: 16px; display: flex; flex-direction: column; gap: 8px;
}
.stanje-contact-text {
  font-family: Inter, sans-serif; font-size: 16px;
  line-height: 24px; letter-spacing: -0.31px; color: white; margin: 0;
}
.stanje-contact-btn {
  display: flex; align-items: center; justify-content: center;
  background: white; border-radius: 10px; height: 48px;
  font-family: Inter, sans-serif; font-size: 16px; font-weight: 600;
  letter-spacing: -0.31px; color: #005776;
  text-decoration: none; transition: background 180ms ease;
}
.stanje-contact-btn:hover { background: #f0f9ff; }
/* responsive */
@media (max-width: 1365px) {
  .stanje-section { padding: 80px 120px 64px; }
  .stanje-title { font-size: 56px; }
  .stanje-cards { grid-template-columns: minmax(0,1fr) 300px 300px minmax(0,1fr); gap: 24px; }
  .stanje-card-value { font-size: 52px; }
}
@media (max-width: 1179px) {
  .stanje-section { padding: 72px 80px 56px; }
  .stanje-title { font-size: 48px; }
  .stanje-cards { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; height: auto; }
  .stanje-maprow { height: auto; flex-direction: column; }
  .stanje-map { height: 400px; border-radius: 16px 16px 0 0; }
  .stanje-map-img { height: 100%; top: 0; }
  .stanje-panel { width: 100%; border-left: none; border-top: 1px solid #e5e7eb; border-radius: 0 0 16px 16px; }
  .stanje-panel-body { overflow-y: visible; }
}
@media (max-width: 1023px) {
  .stanje-section { padding: 56px 48px 48px; }
  .stanje-title { font-size: 40px; }
  .stanje-cards { grid-template-columns: 1fr 1fr; height: auto; gap: 16px; }
  .stanje-card { padding: 24px; }
  .stanje-card-value { font-size: 44px; }
  .stanje-notices { padding: 28px; }
}
@media (max-width: 639px) {
  .stanje-section { padding: 48px 16px 40px; }
  .stanje-title { font-size: 36px; }
  .stanje-cards { grid-template-columns: 1fr; height: auto; gap: 12px; }
  .stanje-card { padding: 20px; flex-direction: row; align-items: center; gap: 16px; }
  .stanje-card-top { height: auto; margin-bottom: 0; flex-direction: column; align-items: flex-start; gap: 4px; }
  .stanje-card-value { font-size: 36px; }
  .stanje-notices { padding: 20px; }
  .stanje-notice { padding: 20px 16px; }
}

/* ============================================================
   PAGE HERO  (reusable interior-page banner)
   ============================================================ */
.page-hero {
  position: relative;
  min-height: 425px;
  overflow: hidden;
  display: flex;
  align-items: stretch;
}
.page-hero-visual {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.page-hero-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url('../images/hero-presentation-crop.png');
  background-size: cover;
    background-position: center !important;
}
.page-hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, rgba(0,0,0,0.10) 0%, rgba(0,0,0,0.58) 100%);
}
.page-hero-inner {
  position: relative;
  z-index: 2;
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-bottom: 60px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
  width: 100%;
  padding-left: max(71px, calc((100% - 1248px) / 2));
  padding-right: max(71px, calc((100% - 1248px) / 2));
}
.page-hero-breadcrumb {
  display: flex;
  align-items: center;
  gap: 13px;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  color: rgba(255,255,255,0.75);
  align-self: flex-start;
}
.page-hero-breadcrumb-link {
  color: rgba(255,255,255,0.75);
  text-decoration: none;
    color:  #FFF;
    font-family: Poppins, sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px; /* 100% */
}
.page-hero-breadcrumb-link:hover { color: #fff; }
.page-hero-breadcrumb-sep { color: rgba(255,255,255,0.5); }
.page-hero-breadcrumb-current {
    color:  #FFF;
    font-family: Poppins, sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px; /* 100% */
}
.page-hero-title {
  font-family: 'Ariata Display', 'Playfair Display', serif;
  font-size: 96px;
  font-weight: 400;
  line-height: 1;
  color: #ffffff;
  margin: 0;
  align-self: flex-end;
}
.page-hero-ellipsis {
  color: rgba(255,255,255,0.75);
}

/* ============================================================
   ABOUT SECTION  –  Vaše sigurno mjesto na moru
   ============================================================ */
.about-section {
  position: relative;
  background:
    radial-gradient(circle at 18% 18%, rgba(206, 218, 226, 0.18), transparent 30%),
    radial-gradient(circle at 84% 62%, rgba(214, 224, 231, 0.16), transparent 28%),
    #ffffff;
  padding: 108px 0 156px;
  overflow: hidden;
}
.about-pattern {
  position: absolute;
  left: 0;
  top: 118px;
  width: 390px;
  height: auto;
  pointer-events: none;
  z-index: 0;
  opacity: 1;
}
.about-side-line {
  position: absolute;
  left: 72px;
  bottom: 224px;
  width: 251px;
  height: auto;
  pointer-events: none;
  opacity: 0.38;
}
.about-watermark {
  position: absolute;
  right: 118px;
  top: 152px;
  width: 860px;
  height: auto;
  pointer-events: none;
  opacity: 0.12;
}
.about-compass {
  position: absolute;
  right: 36px;
  bottom: 188px;
  width: 146px;
  height: auto;
  pointer-events: none;
  opacity: 0.14;
}
.about-shell {
  position: relative;
  z-index: 1;
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
}
.about-content {
  position: relative;
}
.about-eyebrow {
  font-family: 'Ariata Display', 'Playfair Display', serif;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.3;
  color: #abb0ba;
  margin: 0 0 22px;
}
.about-title {
  font-family: 'Ariata Display', 'Playfair Display', serif;
  font-size: 72px;
  font-weight: 400;
  line-height: 1;
  color: #97b1ba;
  letter-spacing: -0.02em;
  margin: 0 0 52px;
}
.about-body {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: min(910px, calc(100% - 72px));
  margin-left: 74px;
}
.about-body p {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  color: #7c8087;
  margin: 0 0 18px;
}
.about-body p:last-child { margin-bottom: 0; }
.about-body strong {
  font-weight: 700;
  color: #7c8087;
}

/* ============================================================
   APPS SECTION  –  Planirajte pametno uz aplikacije naših partnera
   ============================================================ */
.about-apps-section {
  position: relative;
  z-index: 2;
  background: #ffffff;
  margin-top: -48px;
  padding: 0 0 96px;
}
.about-apps-shell {
  width: min(1488px, calc(100% - 96px));
  margin: 0 auto;
}
.about-apps-card {
  position: relative;
  background: #ffffff;
  border-radius: 26px;
  padding: 42px 54px 34px;
  display: flex;
  align-items: center;
  gap: 44px;
  box-shadow: 0 24px 70px rgba(40, 64, 79, 0.14);
}
.about-apps-accent {
  position: absolute;
  left: 54px;
  top: 18px;
  width: 30px;
  height: 4px;
  background: #005776;
}
.about-apps-text {
  flex: 1 1 58%;
  min-width: 0;
}
.about-apps-title {
  font-family: 'Ariata Display', 'Playfair Display', serif;
  font-size: 42px;
  font-weight: 400;
  line-height: 0.94;
  color: #859da6;
  margin: 0;
  max-width: 680px;
}
.about-apps-divider {
  width: 1px;
  align-self: stretch;
  background: rgba(151, 177, 186, 0.45);
}
.about-apps-btn {
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.about-apps-buttons {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 0 0 auto;
}
.about-apps-logo-tile {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 264px;
  height: 58px;
  border-radius: 6px;
  overflow: hidden;
  background: #f4f7f9;
  box-shadow: inset 0 0 0 1px rgba(0, 87, 118, 0.08);
}
.about-apps-logo-tile--walkdock {
  background: #07131f;
}
.about-apps-logo-tile--weather {
  background: linear-gradient(180deg, #596062 0%, #3d4446 100%);
}
.about-apps-img {
  width: 254px;
  height: auto;
  display: block;
}
.about-apps-weather-mark {
  width: 57px;
  height: 57px;
  display: block;
}
.about-apps-link {
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 21px;
  color: #0068ac;
  text-decoration: none;
  text-align: center;
  display: block;
  width: 100%;
}
.about-apps-link:hover { text-decoration: underline; }

/* ============================================================
   VIDEO SECTION  –  Promotivni video
   ============================================================ */
.about-video-section {
  position: relative;
  aspect-ratio: 1920 / 610;
  overflow: hidden;
  background: #082d39;
}
.about-video-reference {
  position: absolute;
  inset: 0;
}
.about-video-reference img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(3, 22, 30, 0.18) 0%, rgba(3, 22, 30, 0.42) 100%);
  z-index: 1;
}
.about-video-inner {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 26px;
  text-align: center;
  padding: 48px 24px;
}
.about-video-play {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #005776;
  text-decoration: none;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.18);
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}
.about-video-play:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 24px 52px rgba(0, 0, 0, 0.24);
  background: #ffffff;
}
.about-video-play svg {
  width: 30px;
  height: 30px;
  margin-left: 6px;
}
.about-video-title {
  margin: 0;
  font-family: 'Ariata Display', 'Playfair Display', serif;
  font-size: 68px;
  font-weight: 400;
  line-height: 0.94;
  letter-spacing: -0.02em;
  color: #ffffff;
  text-wrap: balance;
}
.about-video-sub {
  margin: 0;
  max-width: 640px;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  line-height: 24px;
  color: rgba(255, 255, 255, 0.82);
}

/* ============================================================
   ABOUT PAGE – RESPONSIVE
   ============================================================ */
@media (max-width: 1365px) {
  .about-shell,
  .about-apps-shell {
    width: calc(100% - 96px);
  }
  .about-section { padding: 96px 0 144px; }
  .about-title { font-size: 60px; }
  .about-body { width: min(820px, calc(100% - 48px)); margin-left: 48px; }
  .about-watermark { width: 660px; right: 56px; top: 214px; }
  .about-compass { width: 118px; right: 20px; bottom: 182px; }
  .about-apps-card { padding: 40px 40px 32px; gap: 32px; }
  .about-apps-accent { left: 40px; }
  .about-apps-title { font-size: 48px; max-width: 560px; }
  .about-apps-logo-tile { width: 220px; }
  .page-hero { min-height: 360px; }
  .about-video-title { font-size: 58px; }
}
@media (max-width: 1023px) {
  .about-shell,
  .about-apps-shell {
    width: calc(100% - 48px);
  }
  .about-section { padding: 72px 0 120px; }
  .about-pattern { width: 280px; top: 80px; }
  .about-side-line { left: 18px; bottom: 184px; width: 180px; }
  .about-watermark { width: 420px; right: -40px; top: 320px; opacity: 0.11; }
  .about-compass { width: 92px; right: -8px; bottom: 170px; }
  .about-title { font-size: 48px; }
  .about-body { width: min(100%, calc(100% - 16px)); margin-left: 0; }
  .about-apps-section { margin-top: -28px; padding-bottom: 72px; }
  .about-apps-card { flex-direction: column; align-items: flex-start; gap: 24px; padding: 32px 28px 28px; border-radius: 22px; }
  .about-apps-accent { left: 28px; }
  .about-apps-divider { width: 100%; height: 1px; }
  .about-apps-buttons { width: 100%; justify-content: space-between; flex-wrap: wrap; }
  .about-apps-title { font-size: 38px; max-width: none; }
  .page-hero { min-height: 300px; }
  .about-video-play { width: 84px; height: 84px; }
  .about-video-title { font-size: 46px; }
  .about-video-sub { max-width: 520px; font-size: 15px; line-height: 23px; }
}
@media (max-width: 767px) {
  .about-side-line,
  .about-compass {
    display: none;
  }
  .about-pattern { width: 210px; top: 72px; opacity: 0.1; }
  .about-watermark { width: 280px; right: -48px; top: 350px; opacity: 0.1; }
  .about-title { font-size: 40px; }
  .about-eyebrow { font-size: 20px; }
  .about-section { padding: 72px 0 80px; }
  .about-body p { font-size: 15px; line-height: 23px; }
  .about-apps-section { margin-top: 0; padding-bottom: 56px; }
  .about-apps-card { padding: 28px 20px 24px; }
  .about-apps-accent { left: 20px; top: 16px; }
  .about-apps-title { font-size: 34px; }
  .about-apps-buttons { gap: 18px; }
  .about-apps-btn { width: 100%; }
  .about-apps-logo-tile { width: 100%; max-width: 264px; }
  .page-hero { min-height: 220px; }
  .about-video-inner { gap: 18px; padding: 32px 16px; }
  .about-video-play { width: 70px; height: 70px; }
  .about-video-play svg { width: 24px; height: 24px; margin-left: 4px; }
  .about-video-title { font-size: 34px; }
  .about-video-sub { max-width: 340px; font-size: 14px; line-height: 21px; }
}
@media (max-width: 639px) {
  .about-shell,
  .about-apps-shell {
    width: calc(100% - 32px);
  }
  .about-title { font-size: 34px; }
  .about-apps-title { font-size: 30px; }
}

/* ============================================================
   PAGE HERO MODIFIERS
   ============================================================ */
.page-hero--komv .page-hero-bg {
  background-image: url('../images/hero-presentation-crop.png');
  background-position: center 40%;
}
.page-hero--komun .page-hero-bg {
  background-image: url('../images/hero-presentation-crop.png');
  background-position: center 55%;
}
.page-hero--usluge .page-hero-bg {
  background-image: url('../images/hero-presentation-crop.png');
  background-position: center 20%;
}
.page-hero--docs .page-hero-bg {
  background-image: url('../images/hero-presentation-crop.png');
  background-position: center 35%;
}
.page-hero--about .page-hero-bg {
  background-image: url('../images/hero-presentation-crop.png');
  background-position: center 38%;
}
.page-hero--petrovac .page-hero-bg {
  background-image: url('../images/figmaassets/Image-1.png');
  background-position: center center;
}
.page-hero--about .page-hero-inner,
.page-hero--komv .page-hero-inner,
.page-hero--komun .page-hero-inner,
.page-hero--docs .page-hero-inner,
.page-hero--ferry .page-hero-inner,
.page-hero--petrovac .page-hero-inner,
.page-hero--aktuelnosti .page-hero-inner,
.page-hero--usluge .page-hero-inner,
.page-hero--blueflag .page-hero-inner,
.page-hero--galerija .page-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 0 40px;
  min-height: 100%;
  padding-top: 48px;
  padding-bottom: 28px;
}
.page-hero--about .page-hero-breadcrumb,
.page-hero--komv .page-hero-breadcrumb,
.page-hero--komun .page-hero-breadcrumb,
.page-hero--docs .page-hero-breadcrumb,
.page-hero--ferry .page-hero-breadcrumb,
.page-hero--petrovac .page-hero-breadcrumb,
.page-hero--aktuelnosti .page-hero-breadcrumb,
.page-hero--usluge .page-hero-breadcrumb,
.page-hero--blueflag .page-hero-breadcrumb,
.page-hero--galerija .page-hero-breadcrumb {
  grid-column: 1;
  grid-row: 1;
  align-self: end;
  margin-bottom: 12px;
  max-width: 100%;
  flex-wrap: wrap;
}
.page-hero--about .page-hero-title,
.page-hero--komv .page-hero-title,
.page-hero--komun .page-hero-title,
.page-hero--docs .page-hero-title,
.page-hero--ferry .page-hero-title,
.page-hero--petrovac .page-hero-title,
.page-hero--aktuelnosti .page-hero-title,
.page-hero--usluge .page-hero-title,
.page-hero--blueflag .page-hero-title,
.page-hero--galerija .page-hero-title {
  grid-column: 2;
  grid-row: 1;
  align-self: end;
  justify-self: end;
  max-width: min(52vw, 760px);
  font-size: clamp(56px, 4.6vw, 86px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  text-align: right;
  transform: translateY(4px);
}
.page-hero--about .page-hero-title,
.page-hero--usluge .page-hero-title,
.page-hero--komv .page-hero-title,
.page-hero--komun .page-hero-title,
.page-hero--docs .page-hero-title,
.page-hero--ferry .page-hero-title {
  max-width: min(58vw, 920px);
  font-size: clamp(48px, 4.1vw, 80px);
}

@media (max-width: 1023px) {
  .page-hero--about .page-hero-inner,
  .page-hero--komv .page-hero-inner,
  .page-hero--komun .page-hero-inner,
  .page-hero--docs .page-hero-inner,
  .page-hero--ferry .page-hero-inner,
  .page-hero--petrovac .page-hero-inner,
  .page-hero--aktuelnosti .page-hero-inner,
  .page-hero--usluge .page-hero-inner,
  .page-hero--blueflag .page-hero-inner,
  .page-hero--galerija .page-hero-inner {
    grid-template-columns: 1fr;
    gap: 14px;
    padding-bottom: 32px;
  }
  .page-hero--about .page-hero-breadcrumb,
  .page-hero--komv .page-hero-breadcrumb,
  .page-hero--komun .page-hero-breadcrumb,
  .page-hero--docs .page-hero-breadcrumb,
  .page-hero--ferry .page-hero-breadcrumb,
  .page-hero--petrovac .page-hero-breadcrumb,
  .page-hero--aktuelnosti .page-hero-breadcrumb,
  .page-hero--usluge .page-hero-breadcrumb,
  .page-hero--blueflag .page-hero-breadcrumb,
  .page-hero--galerija .page-hero-breadcrumb,
  .page-hero--about .page-hero-title,
  .page-hero--komv .page-hero-title,
  .page-hero--komun .page-hero-title,
  .page-hero--docs .page-hero-title,
  .page-hero--ferry .page-hero-title,
  .page-hero--petrovac .page-hero-title {
    grid-column: 1;
  }
  .page-hero--aktuelnosti .page-hero-title,
  .page-hero--usluge .page-hero-title,
  .page-hero--blueflag .page-hero-title,
  .page-hero--galerija .page-hero-title {
    grid-column: 1;
  }
  .page-hero--about .page-hero-title,
  .page-hero--komv .page-hero-title,
  .page-hero--komun .page-hero-title,
  .page-hero--docs .page-hero-title,
  .page-hero--ferry .page-hero-title,
  .page-hero--petrovac .page-hero-title {
    justify-self: start;
    max-width: 100%;
    text-align: left;
    transform: none;
  }
  .page-hero--aktuelnosti .page-hero-title,
  .page-hero--usluge .page-hero-title,
  .page-hero--blueflag .page-hero-title,
  .page-hero--galerija .page-hero-title {
    justify-self: start;
    max-width: 100%;
    text-align: left;
    transform: none;
  }
}

/* ============================================================
   KOMERCIJALNI VEZOVI — PREGLED DOSTUPNIH VEZOVA
   ============================================================ */
.komv-section {
  padding: 100px 0 100px;
  background: #ffffff;
}
.komv-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
}
.komv-header {
  margin-bottom: 48px;
  padding-left: 24px;
}
.komv-title {
  font-family: 'Ariata Display', serif;
  font-size: 56px;
  font-weight: 400;
  color: #97B1BA;
  line-height: 1.1;
  margin: 0;
}
.komv-body {
  display: flex;
  gap: 56px;
  align-items: flex-start;
    margin-left: 110px;
    flex-wrap: wrap !important;
}
.komv-text {
  min-width: 0;
}
.komv-text p {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 27px;
  color: #696D73;
  margin: 0 0 20px;
}
.komv-doc-list {
  margin: 0 0 20px 0;
  padding: 0;
  list-style: none;
}
.komv-doc-list li {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 27px;
  color: #696D73;
  padding-left: 22px;
  position: relative;
  margin-bottom: 8px;
}
.komv-doc-list li::before {
  content: '·';
  position: absolute;
  left: 4px;
  color: #696D73;
    font-size: 40px;
  top: -2px;
}

/* ============================================================
   CHECKOUT FORM PANEL
   ============================================================ */
.komv-form-wrap {
  display: flex;
  flex-direction: column;
    width: 100%;
  gap: 0;
}
.checkout-summary {
  background: #ffffff;
  border: 1px solid #d6e6ed;
  border-radius: 12px 12px 0 0;
  padding: 28px 28px 20px;
}
.checkout-summary-title {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #02394c;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 20px;
}
.checkout-summary-item {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.checkout-summary-thumb {
  width: 52px;
  height: 44px;
  background: #e4f0f5;
  border-radius: 6px;
  flex-shrink: 0;
}
.checkout-summary-detail {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.checkout-summary-name {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: #02394c;
}
.checkout-summary-qty {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: #859da6;
}
.checkout-summary-price {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #02394c;
}
.checkout-summary-divider {
  height: 1px;
  background: #e0eaf0;
  margin: 12px 0;
}
.checkout-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #97b1ba;
  margin-bottom: 8px;
}
.checkout-summary-row--total {
  font-size: 16px;
  font-weight: 700;
  color: #02394c;
  margin-top: 4px;
  margin-bottom: 0;
}
.checkout-billing {
  background: #ffffff;
  border: 1px solid #d6e6ed;
  border-top: none;
  padding: 24px 28px 0;
}
.checkout-billing-title {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #02394c;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 6px;
}
.checkout-billing-sub {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: #859da6;
  margin: 0 0 20px;
  line-height: 1.5;
}
.checkout-form { display: flex; flex-direction: column; gap: 14px; }
.checkout-form-row {
  display: flex;
  gap: 14px;
}
.checkout-form-row .checkout-form-group { flex: 1; }
.checkout-form-group {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.checkout-form-group label {
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #02394c;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.checkout-form-group input {
  height: 40px;
  padding: 0 12px;
  border: 1px solid #c8d8e0;
  border-radius: 6px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #02394c;
  background: #f8fbfc;
  outline: none;
  transition: border-color 0.2s;
}
.checkout-form-group input:focus {
  border-color: #005776;
  background: #fff;
}
.checkout-payment {
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid #e0eaf0;
}
.checkout-payment-title {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #02394c;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 14px;
}
.checkout-payment-methods {
  display: flex;
  gap: 10px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.checkout-pay-opt {
  flex: 1;
  min-width: 110px;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 12px;
  border: 1.5px solid #c8d8e0;
  border-radius: 8px;
  cursor: pointer;
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: #859da6;
  transition: border-color 0.2s, color 0.2s;
}
.checkout-pay-opt input[type="radio"] { display: none; }
.checkout-pay-opt--active,
.checkout-pay-opt:has(input:checked) {
  border-color: #005776;
  color: #005776;
  background: #f0f7fa;
}
.checkout-card-fields { display: flex; flex-direction: column; gap: 14px; }
.checkout-submit {
  display: block;
  width: calc(100% + 56px);
  margin-left: -28px;
  margin-top: 20px;
  padding: 18px 28px;
  background: #02394c;
  color: #ffffff;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: background 0.2s;
}
.checkout-submit:hover { background: #005776; }
.checkout-links {
  width: calc(100% + 56px);
  margin-left: -28px;
  padding: 14px 28px;
  background: #f5f9fb;
  border: 1px solid #d6e6ed;
  border-top: none;
  border-radius: 0 0 12px 12px;
  text-align: center;
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  margin-bottom: 0;
}
.checkout-links a {
  color: #005776;
  text-decoration: none;
  transition: color 0.2s;
}
.checkout-links a:hover { color: #02394c; text-decoration: underline; }

/* ============================================================
   KOMUNALNI VEZOVI — DOCS SECTION
   ============================================================ */
.komun-docs-section {
  position: relative;
  padding: 100px 0 90px;
  background: #ffffff;
  overflow: hidden;
}
.komun-pattern {
  position: absolute;
  left: -40px;
  top: 80px;
  width: 220px;
  opacity: 0.18;
  z-index: 0;
  pointer-events: none;
}
.komun-pattern img { width: 100%; display: block; }
.komun-anchor {
  position: absolute;
  right: 60px;
  top: 120px;
  width: 240px;
  opacity: 0.12;
  z-index: 0;
  pointer-events: none;
}
.komun-anchor img { width: 100%; display: block; }
.komun-docs-shell {
  position: relative;
  z-index: 1;
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.komun-docs-header { margin-bottom: 32px; }
.komun-docs-title {
  font-family: 'Ariata Display', serif;
  font-size: 52px;
  font-weight: 400;
  color: #859da6;
  line-height: 1.15;
  margin: 0;
}
.komun-docs-title-sub {
  font-size: 42px;
  color: #859da6;
}
.komun-docs-intro {
  max-width: 720px;
  margin-bottom: 48px;
}
.komun-docs-intro p {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 26px;
  color: #02394c;
  margin: 0 0 12px;
}
.komun-steps {
  max-width: 680px;
}
.komun-step {
  display: flex;
  align-items: flex-start;
  gap: 28px;
  padding: 20px 0;
}
.komun-step-num {
  font-family: 'Ariata Display', serif;
  font-size: 60px;
  font-weight: 400;
  color: #97b1ba;
  line-height: 1;
  flex-shrink: 0;
  min-width: 80px;
  opacity: 0.55;
}
.komun-step-info { padding-top: 4px; }
.komun-step-title {
  font-family: 'Ariata Display', serif;
  font-size: 32px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 6px;
  line-height: 1.2;
  text-transform: capitalize;
}
.komun-step-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 22px;
  color: #859da6;
  margin: 0;
}
.komun-step-divider {
  height: 1px;
  background: linear-gradient(to right, #97b1ba 0%, transparent 60%);
  opacity: 0.35;
}
.komun-docs-note {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid #e0eaf0;
}
.komun-docs-note p {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 24px;
  color: #859da6;
  margin: 0 0 8px;
}

/* ============================================================
   KOMUNALNI — KANCELARIJA BANNER
   ============================================================ */
.komun-banner {
  background: #02394c;
  padding: 32px 0;
  text-align: center;
}
.komun-banner-text {
  font-family: 'Manrope', sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0;
}

/* ============================================================
   KOMUNALNI — SERVIS SECTION
   ============================================================ */
.komun-servis-section {
  position: relative;
  padding: 96px 0 96px;
  background: #ffffff;
  overflow: hidden;
}
.komun-servis-wave {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: linear-gradient(to bottom right, #f0f7fa 0%, transparent 100%);
  opacity: 0.6;
}
.komun-servis-shell {
  position: relative;
  z-index: 1;
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 64px;
  padding-left: 24px;
}
.komun-servis-text { flex: 1; min-width: 0; }
.komun-servis-label {
  display: block;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #87d0f5;
  margin-bottom: 12px;
}
.komun-servis-title {
  font-family: 'Ariata Display', serif;
  font-size: 52px;
  font-weight: 400;
  color: #005776;
  line-height: 1.15;
  margin: 0 0 16px;
}
.komun-servis-title-accent { color: #87d0f5; }
.komun-servis-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 26px;
  color: #859da6;
  margin: 0 0 36px;
  max-width: 480px;
}
.komun-servis-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.komun-servis-btn {
  display: inline-flex;
  align-items: center;
  padding: 14px 28px;
  border-radius: 6px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.komun-servis-btn--primary {
  background: #005776;
  color: #ffffff;
  border: 2px solid #005776;
}
.komun-servis-btn--primary:hover { background: #02394c; border-color: #02394c; }
.komun-servis-btn--ghost {
  background: transparent;
  color: #005776;
  border: 2px solid transparent;
}
.komun-servis-btn--ghost:hover { color: #02394c; }
.komun-servis-img-wrap {
  flex: 0 0 480px;
}
.komun-servis-img-wrap img {
  width: 100%;
  border-radius: 12px;
  display: block;
  object-fit: cover;
  aspect-ratio: 4/3;
}

/* ============================================================
   USLUGE PAGE — SERVICE CARDS SECTION
   ============================================================ */
.usluge-intro-section {
  padding: 112px 0 88px;
  background: #ffffff;
}
.usluge-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 6px;
}
.usluge-intro-header { margin-bottom: 68px; }
.usluge-intro-title {
  font-family: 'Ariata Display', serif;
  font-size: 72px;
  font-weight: 400;
  color: #97b1ba;
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 0;
}
.usluge-intro-body {
  max-width: 920px;
  margin-left: 110px;
}
.usluge-intro-body p {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  line-height: 1.8;
  color: #7c8087;
  margin: 0 0 30px;
  max-width: 860px;
}
.usluge-intro-body strong {
  font-weight: 700;
  color: #696d73;
}
/* 2-column service cards grid */
.usluge-cards-section {
  padding: 18px 0 96px;
  background: #ffffff;
}
.usluge-cards-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 6px;
}
.usluge-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 20px;
}
.usluge-card {
  position: relative;
  background: #005776;
  border-radius: 26px;
  padding: 34px 34px 30px;
  display: flex;
  align-items: flex-start;
  gap: 22px;
  transition: background 0.2s, transform 0.2s;
  min-height: 276px;
  overflow: hidden;
}
.usluge-card::after {
  content: "";
  position: absolute;
  right: -12px;
  bottom: -30px;
  width: 260px;
  height: 168px;
  background: url('../images/logohomevezinfo.svg') no-repeat center / contain;
  opacity: 0.09;
  pointer-events: none;
}
.usluge-card:hover {
  background: #04617f;
  transform: translateY(-2px);
}
.usluge-card-icon {
  flex-shrink: 0;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  display: flex;
  align-items: center;
  justify-content: center;
}
.usluge-card-icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter: none;
}
.usluge-card-body {
  position: relative;
  z-index: 1;
  flex: 1;
  padding-top: 2px;
}
.usluge-card-title {
  font-family: 'Ariata Display', serif;
  font-size: 42px;
  font-weight: 400;
  color: #ffffff;
  margin: 0;
  line-height: 1;
  letter-spacing: -0.02em;
}
.usluge-card-rule {
  display: block;
  width: 48px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.96);
  margin: 20px 0 24px;
}
.usluge-card-desc {
  font-family: 'Montserrat', sans-serif;
  font-size: 15px;
  line-height: 1.65;
  color: rgba(255,255,255,0.84);
  margin: 0;
  max-width: 438px;
}

/* Usluge — Numbered services with images */
.usluge-services-section {
  padding: 0 0 96px;
  background: #ffffff;
}
.usluge-services-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.usluge-service-item {
  display: flex;
  align-items: flex-start;
  gap: 32px;
  padding: 36px 0;
  border-bottom: 1px solid #e0eaf0;
}
.usluge-service-item:last-child { border-bottom: none; }
.usluge-service-num {
  font-family: 'Ariata Display', serif;
  font-size: 80px;
  font-weight: 400;
  color: #97b1ba;
  opacity: 0.35;
  line-height: 1;
  flex-shrink: 0;
  min-width: 100px;
}
.usluge-service-icon {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  margin-top: 8px;
}
.usluge-service-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0.7;
}
.usluge-service-text { flex: 1; padding-top: 4px; }
.usluge-service-title {
  font-family: 'Ariata Display', serif;
  font-size: 36px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 10px;
  line-height: 1.2;
}
.usluge-service-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 25px;
  color: #859da6;
  margin: 0;
  max-width: 480px;
}
.usluge-service-img {
  flex: 0 0 280px;
}
.usluge-service-img img {
  width: 100%;
  border-radius: 10px;
  display: block;
  object-fit: cover;
  aspect-ratio: 4/3;
}

.about-apps-section--usluge {
  padding-top: 22px;
  padding-bottom: 118px;
}
.about-apps-section--usluge .about-apps-shell {
  width: min(1590px, calc(100% - 110px));
}
.about-apps-section--usluge .about-apps-card {
  border-radius: 26px;
  padding: 40px 52px 32px;
  gap: 42px;
  box-shadow: 0 28px 80px rgba(41, 72, 91, 0.14);
}
.about-apps-section--usluge .about-apps-title {
  font-size: 64px;
  line-height: 0.92;
  max-width: 700px;
}
.about-apps-section--usluge .about-apps-divider {
  background: rgba(151, 177, 186, 0.38);
}

.komun-servis-section--usluge {
  background: #ffffff;
  padding: 98px 0 42px;
}
.komun-servis-section--usluge::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 8px;
  width: 626px;
  height: 764px;
  background: url('../images/figmaassets/Decorative Image.png') no-repeat center / contain;
  opacity: 0.12;
  pointer-events: none;
}
.komun-servis-section--usluge::after {
  content: "";
  position: absolute;
  right: -8px;
  top: 18px;
  width: 315px;
  height: 786px;
  background: url('../images/figmaassets/Anchor Image.png') no-repeat center / contain;
  opacity: 1;
  pointer-events: none;
}
.komun-servis-section--usluge .komun-servis-wave {
  display: none;
}
.komun-servis-section--usluge .komun-servis-shell {
  width: min(1540px, calc(100% - 90px));
  padding-left: 0;
  align-items: flex-start;
  gap: 72px;
}
.komun-servis-section--usluge .komun-servis-text {
  flex: 0 0 806px;
  max-width: 806px;
  padding-top: 18px;
}
.komun-servis-section--usluge .komun-servis-label {
  margin: 0 0 6px 226px;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  letter-spacing: 0.16em;
  color: #2ea8d4;
}
.komun-servis-section--usluge .komun-servis-title {
  max-width: 600px;
  margin: 0 0 20px 226px;
  font-size: 78px;
  line-height: 0.92;
  letter-spacing: -0.03em;
  color: #97b1ba;
}
.komun-servis-section--usluge .komun-servis-title-accent {
  color: #0a82b0;
}
.komun-servis-section--usluge .komun-servis-desc {
  max-width: 720px;
  margin: 0 0 38px 226px;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  line-height: 1.65;
  color: #7c8087;
}
.komun-servis-section--usluge .komun-servis-ctas {
  margin-left: 226px;
  align-items: center;
  gap: 40px;
}
.komun-servis-section--usluge .komun-servis-btn {
  border-radius: 0;
  padding: 18px 38px;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}
.komun-servis-section--usluge .komun-servis-btn--primary {
  background: #046e95;
  border-color: #046e95;
}
.komun-servis-section--usluge .komun-servis-btn--primary:hover {
  background: #035777;
  border-color: #035777;
}
.komun-servis-section--usluge .komun-servis-btn--ghost {
  padding-left: 0;
  padding-right: 0;
  color: #047cab;
  border: none;
}
.komun-servis-section--usluge .komun-servis-btn--ghost:hover {
  color: #22a5d8;
}
.komun-servis-section--usluge .komun-servis-img-wrap {
  flex: 0 0 300px;
  width: 300px;
  margin-top: 330px;
}
.komun-servis-section--usluge .komun-servis-img-wrap img {
  border-radius: 0;
  aspect-ratio: 300 / 149;
}

.usluge-services-section--dark {
  position: relative;
  background: #ffffff;
  padding: 0 0 112px;
}
.usluge-services-section--dark::before {
  content: "";
  position: absolute;
  left: -12px;
  top: -118px;
  width: 626px;
  height: 764px;
  background: url('../images/figmaassets/Decorative Image.png') no-repeat center / contain;
  opacity: 0.12;
  pointer-events: none;
}
.usluge-services-section--dark::after {
  content: "";
  position: absolute;
  right: -8px;
  top: -320px;
  width: 315px;
  height: 786px;
  background: url('../images/figmaassets/Anchor Image.png') no-repeat center / contain;
  opacity: 1;
  pointer-events: none;
}
.usluge-services-section--dark .usluge-services-shell {
  position: relative;
  z-index: 1;
  width: min(1540px, calc(100% - 90px));
  padding-left: 0;
}
.usluge-services-section--dark .usluge-service-item {
  gap: 48px;
  padding: 30px 0 58px;
  border-bottom: none;
  min-height: 202px;
}
.usluge-services-section--dark .usluge-service-num {
  min-width: 222px;
  padding-left: 228px;
  font-size: 82px;
  color: #0a82b0;
  opacity: 1;
}
.usluge-services-section--dark .usluge-service-icon {
  width: 76px;
  height: 76px;
  margin-top: 10px;
}
.usluge-services-section--dark .usluge-service-icon img {
  opacity: 0.82;
  filter: grayscale(1) brightness(2.6);
}
.usluge-services-section--dark .usluge-service-text {
  padding-top: 4px;
}
.usluge-services-section--dark .usluge-service-title {
  font-size: 64px;
  line-height: 0.98;
  margin-bottom: 18px;
  color: #97b1ba;
  letter-spacing: -0.025em;
}
.usluge-services-section--dark .usluge-service-desc {
  max-width: 520px;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  line-height: 1.65;
  color: #7c8087;
}
.usluge-services-section--dark .usluge-service-img {
  flex: 0 0 300px;
  width: 300px;
}
.usluge-services-section--dark .usluge-service-img img {
  border-radius: 0;
  aspect-ratio: 300 / 149;
}

/* ============================================================
   DOKUMENTACIJA PAGE
   ============================================================ */
.dokum-section {
  padding: 100px 0 160px;
  background: #ffffff;
}
.dokum-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.dokum-eyebrow {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #87d0f5;
  margin: 0 0 20px;
  display: block;
}
.dokum-title {
  font-family: 'Ariata Display', serif;
  font-size: 80px;
  font-weight: 400;
  color: #005776;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 16px;
  line-height: 1;
}
.dokum-subtitle {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 26px;
  color: #859da6;
  margin: 0 0 56px;
  max-width: 560px;
}
.dokum-download-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.dokum-download-bar {
  width: 32px;
  height: 3px;
  background: #87d0f5;
  border-radius: 2px;
}
.dokum-download-label {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #005776;
}
.dokum-download-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 660px;
}
.dokum-download-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  background: #02394c;
  border-radius: 6px;
  color: #ffffff;
  text-decoration: none;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: background 0.2s;
}
.dokum-download-btn:hover { background: #005776; }
.dokum-download-btn svg {
  flex-shrink: 0;
  opacity: 0.75;
}

/* ============================================================
   PETROVAC PAGE
   ============================================================ */
.petrovac-intro-section {
  padding: 100px 0 80px;
  background: #ffffff;
  position: relative;
  overflow: hidden;
}
.petrovac-anchor {
  position: absolute;
  right: 30px;
  top: 100px;
  width: 300px;
  opacity: 0.08;
  pointer-events: none;
}
.petrovac-anchor img { width: 100%; display: block; }
.petrovac-shell {
  position: relative;
  z-index: 1;
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.petrovac-intro-title {
  font-family: 'Ariata Display', serif;
  font-size: 52px;
  font-weight: 400;
  color: #859da6;
  line-height: 1.2;
  margin: 0 0 32px;
  max-width: 600px;
}
.petrovac-intro-body {
  max-width: 800px;
  margin-bottom: 64px;
}
.petrovac-intro-body p {
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    line-height: 1.8;
    color: #7c8087;
  margin: 0 0 14px;
}
/* Petrovac — two feature cards */
.petrovac-cards-row {
  display: flex;
  gap: 32px;
  align-items: flex-start;
  margin-bottom: 80px;
}
/* Komercijalni dark card */
.petrovac-card--komerz {
  flex: 0 0 340px;
  background: #005776;
  border-radius: 16px;
  padding: 32px 28px;
  color: #ffffff;
}
.petrovac-card-label {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.65);
  margin: 0 0 6px;
}
.petrovac-card-count {
  font-family: 'Ariata Display', serif;
  font-size: 80px;
  font-weight: 400;
  line-height: 1;
  margin: 0 0 28px;
}
.petrovac-card-table { width: 100%; border-collapse: collapse; }
.petrovac-card-table tr + tr td {
  border-top: 1px solid rgba(255,255,255,0.18);
}
.petrovac-card-table td {
  padding: 12px 0;
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,0.85);
}
.petrovac-card-table td:last-child {
  text-align: right;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #87d0f5;
}
.petrovac-card-note {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.18);
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  line-height: 1.6;
}
/* Komunalni white card */
.petrovac-card--komun {
  flex: 1;
  background: #ffffff;
  border: 1.5px solid #d6e6ed;
  border-radius: 16px;
  padding: 32px 28px;
}
.petrovac-card--komun .petrovac-card-label { color: #859da6; }
.petrovac-card--komun .petrovac-card-count { color: #005776; }
.petrovac-komunal-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.petrovac-komunal-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 22px;
  color: #02394c;
}
.petrovac-komunal-list li::before {
  content: '';
  display: block;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  background: #005776;
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}
.petrovac-card-cta {
  display: inline-flex;
  align-items: center;
  margin-top: 28px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #005776;
  text-decoration: none;
}
.petrovac-card-cta:hover { text-decoration: underline; }
/* Petrovac — numbered services (reuse komun-servis style) */
.petrovac-services-section {
  padding: 0 0 80px;
  background: #ffffff;
}
.petrovac-services-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.petrovac-service-item {
  display: flex;
  align-items: flex-start;
  gap: 28px;
  padding: 36px 0;
  border-bottom: 1px solid #e0eaf0;
}
.petrovac-service-item:last-child { border-bottom: none; }
.petrovac-service-num {
  font-family: 'Ariata Display', serif;
  font-size: 56px;
  font-weight: 400;
  color: #97b1ba;
  opacity: 0.4;
  flex-shrink: 0;
  line-height: 1;
  min-width: 72px;
}
.petrovac-service-icon {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  margin-top: 4px;
}
.petrovac-service-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0.7;
}
.petrovac-service-text { flex: 1; padding-top: 2px; }
.petrovac-service-title {
  font-family: 'Ariata Display', serif;
  font-size: 32px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 8px;
  line-height: 1.2;
}
.petrovac-service-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 23px;
  color: #859da6;
  margin: 0;
  max-width: 440px;
}
.petrovac-service-img {
  flex: 0 0 260px;
}
.petrovac-service-img img {
  width: 100%;
  border-radius: 10px;
  display: block;
  object-fit: cover;
  aspect-ratio: 4/3;
}

/* ============================================================
   RESPONSIVE — KOMERCIJALNI VEZOVI
   ============================================================ */
@media (max-width: 1365px) {
  .komv-body { gap: 40px; padding-left: 0; }
  .komv-header { padding-left: 0; }
  .komv-form-wrap { flex: 0 0 380px; }
  .komv-title { font-size: 48px; }
}
@media (max-width: 1023px) {
  .komv-shell { width: calc(100% - 64px); }
  .komv-body { flex-direction: column; gap: 40px; }
  .komv-form-wrap { flex: none; width: 100%; }
  .komv-section { padding: 72px 0 72px; }
}
@media (max-width: 767px) {
  .komv-shell { width: calc(100% - 48px); }
  .komv-title { font-size: 38px; }
  .checkout-summary { padding: 20px; }
  .checkout-billing { padding: 20px 20px 0; }
  .checkout-submit { width: calc(100% + 40px); margin-left: -20px; }
  .checkout-links { width: calc(100% + 40px); margin-left: -20px; padding: 12px 20px; }
  .checkout-form-row { flex-direction: column; gap: 14px; }
  .checkout-payment-methods { flex-direction: column; }
  .checkout-pay-opt { min-width: unset; }
}
@media (max-width: 639px) {
  .komv-shell { width: calc(100% - 32px); }
  .komv-title { font-size: 32px; }
}

/* ============================================================
   RESPONSIVE — KOMUNALNI VEZOVI
   ============================================================ */
@media (max-width: 1365px) {
  .komun-docs-shell { width: calc(100% - 64px); padding-left: 0; }
  .komun-servis-shell { width: calc(100% - 64px); padding-left: 0; }
  .komun-docs-title { font-size: 44px; }
  .komun-docs-title-sub { font-size: 36px; }
  .komun-servis-title { font-size: 44px; }
  .komun-anchor { right: 20px; width: 180px; }
}
@media (max-width: 1023px) {
  .komun-docs-shell { width: calc(100% - 64px); }
  .komun-servis-shell { width: calc(100% - 64px); flex-direction: column; gap: 40px; }
  .komun-servis-img-wrap { flex: none; width: 100%; max-width: 480px; }
  .komun-docs-section { padding: 72px 0 72px; }
  .komun-servis-section { padding: 72px 0 72px; }
  .komun-anchor { display: none; }
}
@media (max-width: 767px) {
  .komun-docs-shell { width: calc(100% - 48px); }
  .komun-servis-shell { width: calc(100% - 48px); }
  .komun-docs-title { font-size: 34px; }
  .komun-docs-title-sub { font-size: 28px; }
  .komun-servis-title { font-size: 34px; }
  .komun-step-num { font-size: 44px; min-width: 60px; }
  .komun-step-title { font-size: 26px; }
  .komun-banner-text { font-size: 14px; letter-spacing: 0.06em; padding: 0 16px; }
}
@media (max-width: 639px) {
  .komun-docs-shell { width: calc(100% - 32px); }
  .komun-servis-shell { width: calc(100% - 32px); }
  .komun-docs-title { font-size: 28px; }
  .komun-servis-ctas { flex-direction: column; }
  .komun-servis-btn { width: 100%; justify-content: center; }
}

/* ============================================================
   RESPONSIVE — USLUGE
   ============================================================ */
@media (max-width: 1365px) {
  .usluge-shell { width: calc(100% - 64px); padding-left: 0; }
  .usluge-cards-shell { width: calc(100% - 64px); padding-left: 0; }
  .usluge-services-shell { width: calc(100% - 64px); padding-left: 0; }
  .usluge-intro-title { font-size: 60px; }
  .usluge-intro-body { margin-left: 52px; max-width: 820px; }
  .usluge-card { min-height: 244px; padding: 28px 28px 24px; }
  .usluge-card-title { font-size: 34px; }
  .about-apps-section--usluge .about-apps-shell { width: calc(100% - 64px); }
  .about-apps-section--usluge .about-apps-card { padding: 36px 40px 28px; gap: 28px; }
  .about-apps-section--usluge .about-apps-title { font-size: 50px; max-width: 560px; }
  .komun-servis-section--usluge::before,
  .usluge-services-section--dark::before { width: 420px; left: -38px; top: 12px; }
  .komun-servis-section--usluge::after,
  .usluge-services-section--dark::after { width: 240px; right: -18px; }
  .komun-servis-section--usluge .komun-servis-shell,
  .usluge-services-section--dark .usluge-services-shell { width: calc(100% - 64px); }
  .komun-servis-section--usluge .komun-servis-label,
  .komun-servis-section--usluge .komun-servis-title,
  .komun-servis-section--usluge .komun-servis-desc,
  .komun-servis-section--usluge .komun-servis-ctas { margin-left: 150px; }
  .komun-servis-section--usluge .komun-servis-title { font-size: 60px; max-width: 520px; }
  .komun-servis-section--usluge .komun-servis-img-wrap { margin-top: 276px; flex-basis: 250px; width: 250px; }
  .usluge-services-section--dark .usluge-service-item { gap: 32px; }
  .usluge-services-section--dark .usluge-service-num { min-width: 150px; padding-left: 150px; font-size: 68px; }
  .usluge-services-section--dark .usluge-service-title { font-size: 50px; }
  .usluge-services-section--dark .usluge-service-img { flex-basis: 250px; width: 250px; }
}
@media (max-width: 1023px) {
  .usluge-shell { width: calc(100% - 64px); }
  .usluge-cards-shell { width: calc(100% - 64px); }
  .usluge-services-shell { width: calc(100% - 64px); }
  .usluge-intro-section { padding: 84px 0 64px; }
  .usluge-intro-header { margin-bottom: 40px; }
  .usluge-intro-body { margin-left: 0; max-width: 100%; }
  .usluge-cards-grid { gap: 14px; }
  .usluge-card { min-height: 220px; border-radius: 20px; }
  .usluge-card-title { font-size: 28px; }
  .usluge-card-desc { font-size: 14px; }
  .about-apps-section--usluge { padding-top: 8px; padding-bottom: 72px; }
  .about-apps-section--usluge .about-apps-shell { width: calc(100% - 64px); }
  .about-apps-section--usluge .about-apps-card { padding: 32px 28px 28px; }
  .about-apps-section--usluge .about-apps-title { font-size: 40px; }
  .usluge-service-img { flex: 0 0 200px; }
  .komun-servis-section--usluge { padding: 72px 0 24px; }
  .komun-servis-section--usluge::before,
  .komun-servis-section--usluge::after,
  .usluge-services-section--dark::before,
  .usluge-services-section--dark::after { display: none; }
  .komun-servis-section--usluge .komun-servis-shell {
    width: calc(100% - 64px);
    flex-direction: column;
    gap: 36px;
  }
  .komun-servis-section--usluge .komun-servis-text { flex: none; max-width: 100%; padding-top: 0; }
  .komun-servis-section--usluge .komun-servis-label,
  .komun-servis-section--usluge .komun-servis-title,
  .komun-servis-section--usluge .komun-servis-desc,
  .komun-servis-section--usluge .komun-servis-ctas { margin-left: 0; }
  .komun-servis-section--usluge .komun-servis-title { font-size: 48px; max-width: 100%; }
  .komun-servis-section--usluge .komun-servis-img-wrap { margin-top: 0; width: min(100%, 420px); flex-basis: auto; }
  .usluge-services-section--dark { padding-bottom: 72px; }
  .usluge-services-section--dark .usluge-services-shell { width: calc(100% - 64px); }
  .usluge-services-section--dark .usluge-service-item {
    display: grid;
    grid-template-columns: 90px 64px minmax(0, 1fr) 220px;
    gap: 24px;
    padding: 28px 0 36px;
    min-height: 0;
  }
  .usluge-services-section--dark .usluge-service-num { min-width: 0; padding-left: 0; font-size: 56px; }
  .usluge-services-section--dark .usluge-service-icon { width: 56px; height: 56px; margin-top: 2px; }
  .usluge-services-section--dark .usluge-service-title { font-size: 38px; }
  .usluge-services-section--dark .usluge-service-img { flex-basis: auto; width: 220px; }
}
@media (max-width: 767px) {
  .usluge-shell { width: calc(100% - 48px); }
  .usluge-cards-shell { width: calc(100% - 48px); }
  .usluge-services-shell { width: calc(100% - 48px); }
  .usluge-cards-grid { grid-template-columns: 1fr; }
  .usluge-intro-title { font-size: 44px; }
  .usluge-intro-body p { font-size: 15px; line-height: 1.7; margin-bottom: 22px; }
  .usluge-card { min-height: 0; padding: 24px 22px 22px; }
  .usluge-card-title { font-size: 32px; }
  .usluge-card-rule { width: 40px; height: 6px; margin: 16px 0 18px; }
  .usluge-service-item { flex-wrap: wrap; }
  .usluge-service-img { flex: 0 0 100%; }
  .usluge-service-num { font-size: 56px; min-width: 72px; }
  .usluge-service-title { font-size: 28px; }
  .about-apps-section--usluge .about-apps-shell { width: calc(100% - 48px); }
  .about-apps-section--usluge .about-apps-title { font-size: 36px; }
  .komun-servis-section--usluge .komun-servis-shell { width: calc(100% - 48px); }
  .komun-servis-section--usluge .komun-servis-title { font-size: 38px; }
  .komun-servis-section--usluge .komun-servis-desc { font-size: 15px; line-height: 1.7; }
  .komun-servis-section--usluge .komun-servis-ctas { gap: 18px; }
  .komun-servis-section--usluge .komun-servis-btn { width: 100%; justify-content: center; }
  .komun-servis-section--usluge .komun-servis-btn--ghost { justify-content: flex-start; }
  .usluge-services-section--dark .usluge-services-shell { width: calc(100% - 48px); }
  .usluge-services-section--dark .usluge-service-item {
    grid-template-columns: 72px 52px minmax(0, 1fr);
    gap: 18px;
    padding: 22px 0 28px;
  }
  .usluge-services-section--dark .usluge-service-num { font-size: 44px; }
  .usluge-services-section--dark .usluge-service-icon { width: 44px; height: 44px; }
  .usluge-services-section--dark .usluge-service-title { font-size: 30px; margin-bottom: 12px; }
  .usluge-services-section--dark .usluge-service-desc { font-size: 14px; line-height: 1.65; max-width: none; }
  .usluge-services-section--dark .usluge-service-img {
    grid-column: 1 / -1;
    width: 100%;
  }
}
@media (max-width: 639px) {
  .usluge-shell { width: calc(100% - 32px); }
  .usluge-cards-shell { width: calc(100% - 32px); }
  .usluge-services-shell { width: calc(100% - 32px); }
  .usluge-intro-title { font-size: 34px; }
  .usluge-card-title { font-size: 28px; }
  .about-apps-section--usluge .about-apps-shell { width: calc(100% - 32px); }
  .about-apps-section--usluge .about-apps-card { padding: 28px 20px 22px; }
  .about-apps-section--usluge .about-apps-title { font-size: 30px; }
  .komun-servis-section--usluge .komun-servis-shell { width: calc(100% - 32px); }
  .usluge-services-section--dark .usluge-services-shell { width: calc(100% - 32px); }
}

/* ============================================================
   RESPONSIVE — DOKUMENTACIJA
   ============================================================ */
@media (max-width: 1365px) {
  .dokum-shell { width: calc(100% - 64px); padding-left: 0; }
  .dokum-title { font-size: 64px; }
}
@media (max-width: 1023px) {
  .dokum-shell { width: calc(100% - 64px); }
  .dokum-title { font-size: 52px; }
  .dokum-section { padding: 72px 0 120px; }
}
@media (max-width: 767px) {
  .dokum-shell { width: calc(100% - 48px); }
  .dokum-title { font-size: 40px; }
  .dokum-download-list { max-width: 100%; }
}
@media (max-width: 639px) {
  .dokum-shell { width: calc(100% - 32px); }
  .dokum-title { font-size: 34px; }
}

/* ============================================================
   RESPONSIVE — PETROVAC
   ============================================================ */
@media (max-width: 1365px) {
  .petrovac-shell { width: calc(100% - 64px); padding-left: 0; }
  .petrovac-services-shell { width: calc(100% - 64px); padding-left: 0; }
  .petrovac-intro-title { font-size: 44px; }
  .petrovac-card--komerz { flex: 0 0 300px; }
}
@media (max-width: 1023px) {
  .petrovac-shell { width: calc(100% - 64px); }
  .petrovac-services-shell { width: calc(100% - 64px); }
  .petrovac-cards-row { flex-direction: column; }
  .petrovac-card--komerz { flex: none; width: 100%; max-width: 400px; }
  .petrovac-intro-title { font-size: 36px; }
  .petrovac-anchor { display: none; }
}
@media (max-width: 767px) {
  .petrovac-shell { width: calc(100% - 48px); }
  .petrovac-services-shell { width: calc(100% - 48px); }
  .petrovac-intro-title { font-size: 30px; }
  .petrovac-service-item { flex-wrap: wrap; }
  .petrovac-service-img { flex: 0 0 100%; }
  .petrovac-service-title { font-size: 26px; }
}
@media (max-width: 639px) {
  .petrovac-shell { width: calc(100% - 32px); }
  .petrovac-services-shell { width: calc(100% - 32px); }
}

/* ============================================================
   PAGE HERO MODIFIERS — GALERIJA / BLUE FLAG / FERRY / AKTUELNOSTI
   ============================================================ */
.page-hero--galerija .page-hero-bg    { background-position: center 25%; }
.page-hero--blueflag .page-hero-bg   { background-position: center 60%; }
.page-hero--ferry .page-hero-bg      { background-image: url('../images/ferry-bg.png'); background-position: center center; }
.page-hero--aktuelnosti .page-hero-bg { background-position: center 35%; }

.page-hero--aktuelnosti + .news-section .news-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
  padding-left: 0;
  justify-content: initial;
  align-items: start;
}

.page-hero--aktuelnosti + .news-section .news-card {
  width: 100%;
  min-width: 0;
}

.page-hero--aktuelnosti + .news-section .news-card-inner {
  width: calc(100% - 57px);
  max-width: 310px;
}

@media (max-width: 1279px) {
  .page-hero--aktuelnosti + .news-section .news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
  }
}

@media (max-width: 767px) {
  .page-hero--aktuelnosti + .news-section .news-grid {
    grid-template-columns: 1fr;
  }

  .page-hero--aktuelnosti + .news-section .news-card {
    max-width: 367px;
    margin: 0 auto;
  }
}

/* ============================================================
   GALERIJA
   ============================================================ */
.gallery-section { padding: 96px 0 120px; background: #ffffff; }
.gallery-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.gallery-header { margin-bottom: 48px; }
.gallery-title {
  font-family: 'Ariata Display', serif;
  font-size: 56px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 10px;
  line-height: 1.1;
}
.gallery-subtitle {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  color: #859da6;
  margin: 0;
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5px;
}
.gallery-item {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 0px;
  aspect-ratio: 4/3;
  background: #e0eaf0;
}
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item-overlay {
  position: absolute;
  inset: 0;
  background: rgba(2, 57, 76, 0.42);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s;
}
.gallery-item:hover .gallery-item-overlay { opacity: 1; }

@media (max-width: 1023px) {
  .gallery-shell { width: calc(100% - 64px); padding-left: 0; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-title { font-size: 44px; }
}
@media (max-width: 639px) {
  .gallery-shell { width: calc(100% - 32px); }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-title { font-size: 34px; }
}

/* ============================================================
   PLAVA ZASTAVICA
   ============================================================ */
.blueflag-section { padding: 100px 0 160px; background: #ffffff; }
.blueflag-shell {
  width: min(900px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.blueflag-title {
  font-family: 'Ariata Display', serif;
  font-size: 56px;
  font-weight: 400;
  color: #859da6;
  margin: 0 0 48px;
  line-height: 1.15;
}
.blueflag-body p {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 28px;
  color: #02394c;
  margin: 0 0 20px;
}
.blueflag-list {
  margin: 0 0 20px 0;
  padding-left: 24px;
  list-style: disc;
}
.blueflag-list li {
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  line-height: 28px;
  color: #02394c;
  margin-bottom: 4px;
}
.blueflag-list li::marker { color: #005776; }
.blueflag-badge-row {
  margin-top: 56px;
  display: flex;
  align-items: center;
  gap: 20px;
}
.blueflag-badge {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #005776;
  line-height: 1.5;
}

@media (max-width: 1023px) {
  .blueflag-shell { width: calc(100% - 64px); padding-left: 0; }
  .blueflag-title { font-size: 44px; }
}
@media (max-width: 767px) {
  .blueflag-shell { width: calc(100% - 48px); }
  .blueflag-title { font-size: 34px; }
}

/* ============================================================
   BUDVA–DUBROVNIK FERRY PAGE
   ============================================================ */
.ferry-intro-section { padding: 96px 0 120px; background: #ffffff; }
.ferry-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
}
.ferry-main-title {
  font-family: 'Ariata Display', serif;
  font-size: 56px;
  font-weight: 400;
  color: #859da6;
  margin: 0 0 40px;
  line-height: 1.1;
}
.ferry-intro-body { max-width: 760px; margin-bottom: 40px; }
.ferry-intro-body p {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 26px;
  color: #02394c;
  margin: 0 0 16px;
}
.ferry-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  background: #02394c;
  color: #ffffff;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  border-radius: 4px;
  margin-bottom: 64px;
  transition: background 0.2s;
}
.ferry-cta-btn:hover { background: #005776; }
.ferry-schedule-block { margin-bottom: 56px; }
.ferry-schedule-title {
  font-family: 'Ariata Display', serif;
  font-size: 32px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 10px;
}
.ferry-schedule-title strong { color: #02394c; }
.ferry-schedule-period {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: #859da6;
  margin: 0 0 20px;
}
.ferry-date-pill {
  display: inline-block;
  color: #fff;
  padding: 2px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
}
.ferry-table-wrap { overflow-x: auto; }
.ferry-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
}
.ferry-table thead tr {
  background: #005776;
  color: #ffffff;
}
.ferry-table thead th {
  padding: 12px 14px;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.06em;
  font-size: 11px;
  text-transform: uppercase;
}
.ferry-table thead th:first-child { text-align: left; min-width: 180px; }
.ferry-table tbody tr { border-bottom: 1px solid #e0eaf0; }
.ferry-table tbody tr:hover { background: #f5f9fb; }
.ferry-table tbody td {
  padding: 12px 14px;
  text-align: center;
  color: #02394c;
}
.ferry-table tbody td:first-child { text-align: left; }
.ferry-route { font-weight: 600; color: #005776; }
.ferry-pricelist-block { margin-top: 24px; }
.ferry-pricelist-title {
  font-family: 'Ariata Display', serif;
  font-size: 36px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 6px;
  letter-spacing: 0.04em;
}
.ferry-pricelist-sub {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #859da6;
  margin: 0 0 20px;
}
.ferry-price-table thead { background: #87d0f5; }
.ferry-price-table thead th { color: #02394c; }
.ferry-price-table tbody tr:nth-child(odd) { background: #f8fbfc; }

@media (max-width: 1023px) {
  .ferry-shell { width: calc(100% - 64px); padding-left: 0; }
  .ferry-main-title { font-size: 44px; }
}
@media (max-width: 767px) {
  .ferry-shell { width: calc(100% - 48px); }
  .ferry-main-title { font-size: 34px; }
  .ferry-schedule-title { font-size: 26px; }
}

/* ============================================================
   NEWS PAGINATION
   ============================================================ */
.news-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 64px;
  padding-top: 40px;
  border-top: 1px solid #e0eaf0;
}
.news-page-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1.5px solid #d6e6ed;
  border-radius: 6px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: #005776;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.news-page-btn:hover { background: #005776; color: #fff; border-color: #005776; }
.news-page-btn--active { background: #005776; color: #fff; border-color: #005776; }
.news-page-btn--arrow { font-size: 18px; font-weight: 400; color: #859da6; }
.news-page-dots { color: #859da6; font-size: 16px; padding: 0 4px; }

/* ============================================================
   AKTUELNOSTI DETALJ — ARTICLE + SIDEBAR
   ============================================================ */
.article-section { padding: 80px 0 100px; background: #ffffff; }
.article-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 64px;
  align-items: flex-start;
}
.article-main {
  min-width: 0;
}
.article-featured-img {
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 36px;
}
.article-featured-img img {
  width: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 16/9;
}
.article-title {
  font-family: 'Ariata Display', serif;
  font-size: 40px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 28px;
  line-height: 1.2;
}
.article-body p {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 27px;
  color: #02394c;
  margin: 0 0 18px;
}
.article-body {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.article-body > * {
  max-width: 100%;
}
.article-body img,
.article-body video,
.article-body canvas,
.article-body svg {
  display: block;
  max-width: 100%;
  height: auto;
}
.article-body iframe,
.article-body embed,
.article-body object {
  display: block;
  max-width: 100%;
  width: 100%;
}
.article-body table {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  border-collapse: collapse;
}
.article-body pre {
  max-width: 100%;
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-word;
}
.article-body a,
.article-body span,
.article-body strong,
.article-body em,
.article-body li,
.article-body td,
.article-body th {
  overflow-wrap: anywhere;
}
.article-body ul,
.article-body ol {
  margin: 0 0 18px;
  padding-left: 24px;
}
.article-body li {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 27px;
  color: #02394c;
  margin-bottom: 8px;
}
.article-body blockquote {
  margin: 0 0 24px;
  padding: 18px 22px;
  border-left: 4px solid #005776;
  background: #f5f9fb;
}
.article-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 28px 0;
}
.article-gallery img {
  width: 100%;
  border-radius: 8px;
  display: block;
  object-fit: cover;
  aspect-ratio: 4/3;
}
.article-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid #e0eaf0;
}
.article-meta-left { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.article-meta-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  color: #859da6;
}
.article-meta-tags { display: flex; align-items: center; gap: 8px; }
.article-tag-label {
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  color: #859da6;
}
.article-tag {
  display: inline-block;
  padding: 3px 10px;
  background: #e0eaf0;
  border-radius: 20px;
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: #005776;
  text-decoration: none;
}
.article-tag:hover { background: #005776; color: #fff; }

/* Sidebar */
.article-sidebar { position: sticky; top: 160px; }
.sidebar-widget { margin-bottom: 36px; }
.sidebar-widget-title {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #02394c;
  margin: 0 0 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid #005776;
  display: inline-block;
}
.sidebar-search-form {
  display: flex;
  border: 1.5px solid #d6e6ed;
  border-radius: 6px;
  overflow: hidden;
}
.sidebar-search-input {
  flex: 1;
  padding: 10px 14px;
  border: none;
  outline: none;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #02394c;
  background: #f8fbfc;
}
.sidebar-search-btn {
  background: #005776;
  border: none;
  padding: 0 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: background 0.2s;
}
.sidebar-search-btn:hover { background: #02394c; }
.sidebar-news-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  text-decoration: none;
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #f0f5f8;
}
.sidebar-news-item:last-child { border-bottom: none; margin-bottom: 0; }
.sidebar-news-thumb {
  width: 64px;
  height: 56px;
  object-fit: cover;
  border-radius: 6px;
  flex-shrink: 0;
}
.sidebar-news-info { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.sidebar-news-title {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #02394c;
  line-height: 1.4;
}
.sidebar-news-date {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  color: #859da6;
}
.sidebar-news-item:hover .sidebar-news-title { color: #005776; }
.sidebar-cat-list {
  list-style: none;
  margin: 0; padding: 0;
}
.sidebar-cat-list li + li { margin-top: 10px; }
.sidebar-cat-list a {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #02394c;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.sidebar-cat-list a::before {
  content: '';
  display: block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #87d0f5;
  flex-shrink: 0;
}
.sidebar-cat-list a:hover { color: #005776; }
.sidebar-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.sidebar-tag {
  display: inline-block;
  padding: 5px 12px;
  border: 1.5px solid #d6e6ed;
  border-radius: 20px;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  color: #005776;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.sidebar-tag:hover { background: #005776; color: #fff; border-color: #005776; }

/* Comments section */
.comments-section { padding: 0 0 100px; background: #ffffff; }
.comments-shell {
  width: min(1248px, calc(100% - 142px));
  margin: 0 auto;
  padding-left: 24px;
  max-width: 860px;
}
.comments-title {
  font-family: 'Ariata Display', serif;
  font-size: 32px;
  font-weight: 400;
  color: #005776;
  margin: 0 0 32px;
}
.comment-item {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  margin-bottom: 36px;
  padding-bottom: 32px;
  border-bottom: 1px solid #e0eaf0;
}
.comment-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.comment-body { flex: 1; }
.comment-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.comment-author {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #02394c;
}
.comment-date {
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  color: #859da6;
}
.comment-reply-btn {
  margin-left: auto;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #005776;
  text-decoration: none;
  padding: 4px 12px;
  border: 1.5px solid #005776;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
}
.comment-reply-btn:hover { background: #005776; color: #fff; }
.comment-text {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 24px;
  color: #859da6;
  margin: 0;
}
.comment-form-wrap { margin-top: 20px; }
.comment-form-note {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: #859da6;
  margin: 0 0 24px;
}
.comment-form { display: flex; flex-direction: column; gap: 16px; }
.comment-form-body { display: flex; flex-direction: column; gap: 14px; }
.comment-textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1.5px solid #d6e6ed;
  border-radius: 8px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #02394c;
  background: #f8fbfc;
  resize: vertical;
  outline: none;
  transition: border-color 0.2s;
}
.comment-textarea:focus { border-color: #005776; background: #fff; }
.comment-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
}
.comment-input {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid #d6e6ed;
  border-radius: 8px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  color: #02394c;
  background: #f8fbfc;
  outline: none;
  transition: border-color 0.2s;
}
.comment-input:focus { border-color: #005776; background: #fff; }
.comment-submit {
  display: inline-block;
  padding: 14px 36px;
  background: #005776;
  color: #fff;
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  align-self: flex-start;
  transition: background 0.2s;
}
.comment-submit:hover { background: #02394c; }

/* Article + comments responsive */
@media (max-width: 1023px) {
  .article-shell { width: calc(100% - 64px); padding-left: 0; grid-template-columns: 1fr; gap: 48px; }
  .article-sidebar { position: static; }
  .comments-shell { width: calc(100% - 64px); padding-left: 0; }
}
@media (max-width: 767px) {
  .article-shell { width: calc(100% - 48px); }
  .comments-shell { width: calc(100% - 48px); }
  .article-title { font-size: 30px; }
  .article-gallery { grid-template-columns: 1fr; }
  .comment-form-row { grid-template-columns: 1fr; }
}
@media (max-width: 639px) {
  .article-shell { width: calc(100% - 32px); }
  .comments-shell { width: calc(100% - 32px); }
}

.search-results-section {
  padding: 96px 0 120px;
  background:
    radial-gradient(circle at top left, rgba(0, 124, 168, 0.08), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f4f8fb 100%);
}

.search-results-shell {
  width: min(1248px, calc(100% - 64px));
  margin: 0 auto;
}

.search-results-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  gap: 24px;
  align-items: end;
  margin-bottom: 42px;
}

.search-results-title {
  margin: 12px 0 10px;
  color: #6f8790;
  font-family: "Ariata Display", Georgia, "Times New Roman", serif;
  font-size: clamp(32px, 4vw, 58px);
  line-height: 1.02;
}

.search-results-query {
  color: #005776;
}

.search-results-meta {
  margin: 0;
  color: #7c8087;
  font-family: Poppins, sans-serif;
  font-size: 15px;
  line-height: 1.7;
}

.search-results-form {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(0, 87, 118, 0.08);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 22px 60px rgba(10, 51, 71, 0.08);
}

.search-results-input {
  width: 100%;
  min-height: 58px;
  border: 0;
  background: transparent;
  color: #0c3b4e;
  font: 500 16px/1.4 Poppins, sans-serif;
  padding: 0 16px;
}

.search-results-input:focus {
  outline: none;
}

.search-results-submit {
  min-width: 132px;
  min-height: 58px;
  border: 0;
  border-radius: 18px;
  background: #005776;
  color: #fff;
  font: 700 12px/1 Montserrat, sans-serif;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  transition: background-color .2s ease, transform .2s ease;
}

.search-results-submit:hover {
  background: #007ca8;
  transform: translateY(-1px);
}

.search-results-groups {
  display: grid;
  gap: 36px;
}

.search-results-group-title {
  margin: 0 0 18px;
  color: #0c3b4e;
  font-family: "Ariata Display", Georgia, "Times New Roman", serif;
  font-size: 32px;
  line-height: 1.08;
}

.search-results-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.search-result-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 220px;
  padding: 28px 24px;
  border: 1px solid rgba(0, 87, 118, 0.08);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 24px 60px rgba(10, 51, 71, 0.08);
}

.search-result-type {
  display: inline-flex;
  align-self: flex-start;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(0, 124, 168, 0.1);
  color: #007ca8;
  font: 700 11px/1 Montserrat, sans-serif;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.search-result-name {
  margin: 0;
  color: #0c3b4e;
  font-family: "Ariata Display", Georgia, "Times New Roman", serif;
  font-size: 28px;
  line-height: 1.12;
}

.search-result-link {
  margin-top: auto;
  color: #005776;
  font: 700 12px/1.4 Montserrat, sans-serif;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
}

.search-result-link:hover {
  color: #007ca8;
}

.search-results-empty {
  padding: 44px 38px;
  border: 1px solid rgba(0, 87, 118, 0.08);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 24px 60px rgba(10, 51, 71, 0.08);
}

.search-results-empty h3 {
  margin: 0 0 10px;
  color: #0c3b4e;
  font-family: "Ariata Display", Georgia, "Times New Roman", serif;
  font-size: 32px;
  line-height: 1.08;
}

.search-results-empty p {
  margin: 0;
  color: #7c8087;
  font: 500 16px/1.75 Poppins, sans-serif;
}

@media (max-width: 1279px) {
  .search-results-shell {
    width: calc(100% - 48px);
  }

  .search-results-head {
    grid-template-columns: 1fr;
  }

  .search-results-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .search-results-section {
    padding: 72px 0 88px;
  }

  .search-results-shell {
    width: calc(100% - 32px);
  }

  .search-results-form {
    flex-direction: column;
    align-items: stretch;
  }

  .search-results-submit {
    width: 100%;
  }

  .search-results-grid {
    grid-template-columns: 1fr;
  }

  .search-result-card {
    min-height: 0;
    padding: 24px 20px;
    border-radius: 24px;
  }
}

/* ── Mobile/tablet refinements (Figma: mobile 430px / tablet 834px) ── */
@media (min-width: 640px) and (max-width: 767px) {
  .infra-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 639px) {
  /* Figma mobile: lokacija sekcija je tamna (multiply preko #062332) */
  .location-section {
    background-blend-mode: multiply;
  }
  .location-section::after {
    width: 100%;
    background: linear-gradient(180deg, rgba(2, 25, 38, 0.45), rgba(2, 25, 38, 0.2) 50%, rgba(2, 25, 38, 0.45));
  }
  /* Figma mobile: kolabirana experience kartica prikazuje naslov na vrhu */
  .experience-card:not(.experience-card-active) {
    justify-content: flex-start;
  }
  .experience-card:not(.experience-card-active) .experience-card-top {
    display: none;
  }
  .experience-card:not(.experience-card-active) .experience-card-title {
    font-size: 28px;
    line-height: 32px;
  }
  /* Figma mobile (1035:10663): local services = bijele kartice na #97b1ba pozadini */
  .local-services-section {
    background: #97b1ba;
    padding: 24px 0 32px;
  }
  .local-services-section::before,
  .local-services-section::after {
    display: none;
  }
  .local-services-title {
    color: #ffffff;
  }
  .local-services-intro .local-services-text,
  .local-services-outro .local-services-text {
    color: #f2f6f8;
  }
  .local-services-list {
    display: flex;
    flex-direction: column;
    gap: 22px;
    width: calc(100% - 24px);
  }
  .local-service-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 64px;
    align-items: center;
    gap: 12px 12px;
    padding: 12px 0 0;
    background: #ffffff;
    border-radius: 12px;
    overflow: hidden;
    border-bottom: none;
  }
  .local-service-row + .local-service-row {
    border-top: none;
  }
  .local-service-number {
    grid-column: 1;
    padding-left: 12px;
    font-size: 64px;
    line-height: 1;
    color: #005776;
    opacity: 0.39;
  }
  .local-service-icon {
    grid-column: 2;
    width: 64px;
    height: 64px;
    margin-right: 12px;
  }
  .local-service-copy {
    grid-column: 1 / -1;
    padding: 0 12px;
  }
  .local-service-thumb {
    grid-column: 1 / -1;
    width: 100%;
    height: 130px;
    object-fit: cover;
    margin: 0;
    border-radius: 0;
  }
}
