/* ============================================================
   ARLEKIN comedy — design system
   Bordo + krem + zlato. Mobile-first responsive.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --bordo:#6e1423;
  --bordo-2:#5a1019;
  --bordo-deep:#3d0b12;
  --cream:#ead4ab;
  --cream-2:#f1e3c6;
  --cream-3:#f7efdd;
  --ink:#2b1216;
  --ink-soft:#6b4a45;
  --gold:#bf8f3b;
  --gold-2:#d8b463;
  --red:#e23b30;
  --line: rgba(110,20,35,.18);

  --f-display:"Cormorant Garamond", Georgia, serif;
  --f-body:"EB Garamond", Georgia, serif;
  --f-ui:"Jost", system-ui, sans-serif;

  --maxw: 1240px;
}

*{ box-sizing:border-box; }
html,body{ margin:0; background:var(--cream); }
.ark{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
  overflow-x:hidden;
}
.ark img{ display:block; max-width:100%; }
.ark a{ color:inherit; text-decoration:none; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 22px; }

/* ---------- typography helpers ---------- */
.kicker{
  font-family:var(--f-ui);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-weight:500;
  font-size:12px;
  color:var(--bordo);
}
.kicker.on-dark{ color:var(--gold-2); }
.serif-italic{ font-family:var(--f-display); font-style:italic; font-weight:500; }
.section-title{
  font-family:var(--f-display);
  font-weight:600;
  font-size:34px;
  line-height:1.06;
  margin:.1em 0 0;
  text-align:center;
}
.section-title em{ font-style:italic; color:var(--gold); }
.gold{ color:var(--gold); }
.sec-sub{ text-align:center; max-width:560px; margin:14px auto 0; color:var(--ink-soft); font-size:16px; }

/* harlequin diamond bullet */
.diamond{ width:11px;height:11px;background:var(--gold);transform:rotate(45deg);display:inline-block; }
.diamond.red{ background:var(--red); }

/* ---------- buttons ---------- */
.btn{
  font-family:var(--f-ui);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:500;
  font-size:12px;
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;
  border:1.5px solid var(--bordo);
  color:var(--bordo);
  background:transparent;
  border-radius:2px;
  cursor:pointer;
  transition:.22s ease;
}
.btn:hover{ background:var(--bordo); color:var(--cream-2); }
.btn.solid{ background:var(--bordo); color:var(--cream-2); }
.btn.solid:hover{ background:var(--bordo-deep); border-color:var(--bordo-deep); }
.btn.ghost-light{ border-color:rgba(255,255,255,.6); color:#fff; }
.btn.ghost-light:hover{ background:#fff; color:var(--bordo); border-color:#fff; }
.btn.gold{ border-color:var(--gold); color:var(--gold-2); }
.btn.gold:hover{ background:var(--gold); color:var(--bordo-deep); border-color:var(--gold); }

/* =====================================================================
   CURTAIN — kazališna zavjesa pri loadanju
   ===================================================================== */
.curtain-stage{
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  display:flex;
}
.curtain-valance{
  position:absolute; top:0; left:0; right:0; height:34px; z-index:2;
  background:
    linear-gradient(180deg, #2a070b 0%, var(--bordo-deep) 30%, #2a070b 100%);
  box-shadow: 0 6px 0 var(--gold), 0 14px 28px rgba(0,0,0,.45);
}
.curtain-side{
  position:relative; width:50%; height:100%;
  background:
    repeating-linear-gradient(90deg,
      rgba(0,0,0,.32) 0 6px,
      rgba(0,0,0,0)   6px 22px,
      rgba(255,255,255,.05) 22px 28px,
      rgba(0,0,0,0)   28px 52px),
    linear-gradient(180deg, var(--bordo-deep), var(--bordo) 35%, #4a0d16 100%);
  box-shadow: inset 0 0 80px rgba(0,0,0,.55);
  transition: transform 1.9s cubic-bezier(.78,.04,.28,1);
}
.curtain-side.left  { transform-origin: left center;  border-right: 4px solid rgba(0,0,0,.4); }
.curtain-side.right { transform-origin: right center; border-left:  4px solid rgba(0,0,0,.4); }
.curtain-open .curtain-side.left  { transform: translateX(-102%); }
.curtain-open .curtain-side.right { transform: translateX( 102%); }
.curtain-fold{
  position:absolute; inset:0;
  background:
    radial-gradient(60% 100% at 0%   50%, rgba(0,0,0,.45), transparent 45%),
    radial-gradient(60% 100% at 100% 50%, rgba(0,0,0,.45), transparent 45%);
  pointer-events:none;
}

/* ---------- nav: sticky, light bg, hamburger always present ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:62;
  display:flex; align-items:center; justify-content:flex-end;
  padding:10px 18px; gap:0;
  background:rgba(241,227,198,.94);
  backdrop-filter:saturate(140%) blur(6px);
  -webkit-backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid rgba(110,20,35,.15);
}
.nav-spacer{ flex:1; }

/* hamburger */
.nav-burger{
  display:flex; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:10px;
  z-index:62;
}
.nav-burger span{ display:block; width:30px; height:3.5px; background:var(--bordo); border-radius:2px; transition:.25s; }
.nav-burger.x span:nth-child(1){ transform:translateY(8.5px) rotate(45deg); }
.nav-burger.x span:nth-child(2){ opacity:0; }
.nav-burger.x span:nth-child(3){ transform:translateY(-8.5px) rotate(-45deg); }

/* dropdown menu */
.nav-menu{
  position:fixed; top:0; right:0; height:100vh; width:min(360px, 86vw);
  background:linear-gradient(180deg, var(--bordo-deep), var(--bordo) 60%, var(--bordo-2));
  z-index:61;
  display:flex; flex-direction:column; padding:88px 0 30px;
  transform:translateX(105%);
  transition:transform .35s cubic-bezier(.4,.0,.2,1);
  box-shadow:-30px 0 60px rgba(0,0,0,.35);
  overflow-y:auto;
}
.nav-menu.open{ transform:translateX(0); }
.nav-menu a{
  font-family:var(--f-ui); text-transform:uppercase; letter-spacing:.16em;
  font-size:13px; color:var(--cream-2);
  padding:18px 30px; border-bottom:1px solid rgba(216,180,99,.18);
  display:block; transition:.18s;
}
.nav-menu a:hover{ background:rgba(0,0,0,.18); color:var(--gold-2); padding-left:36px; }
.nav-menu a.active{ color:var(--gold-2); border-left:3px solid var(--gold); padding-left:27px; }
.nav-menu .nav-soc{ display:flex; gap:18px; padding:24px 30px; margin-top:auto;
  border-top:1px solid rgba(216,180,99,.25); }
.nav-menu .nav-soc a{
  border-bottom:none; padding:6px 0; flex:1;
  color:var(--gold-2); font-weight:500;
}
.nav-menu .nav-soc a:hover{ background:none; color:#fff; padding-left:0; }
.nav-scrim{ position:fixed; inset:0; z-index:60; background:rgba(20,8,10,.4); cursor:pointer; }

/* scroll offset za sidrene linkove (fixed nav je ~64px visok) */
section[id], footer[id]{ scroll-margin-top:80px; }

/* legacy classes — sakrij ako se nekim slučajem renderiraju */
.nav-logo, .nav-links, .nav-mobile{ display:none !important; }

/* ---------- HERO: logo verzija ---------- */
.hero-logo{
  position:relative;
  min-height: 100vh;
  display:flex; flex-direction:column;
  /* SOLID cream — bez gradijenta da multiply savršeno makne bijelu */
  background: var(--cream);
  overflow:hidden;
  padding-top:70px; /* prostor za fixed nav */
}
.hero-logo::after{
  content:""; position:absolute; inset:auto 0 0 0; height:50%; z-index:0;
  background:
    repeating-linear-gradient(45deg,
      rgba(110,20,35,.04) 0 18px,
      transparent 18px 36px);
  pointer-events:none;
}
.hero-logo-wrap{
  position:relative; z-index:2;
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:30px 22px 50px;
}
.hero-logo .hero-kapa{
  width:min(56vw, 220px);
  height:auto;
  mix-blend-mode: darken;
  animation: logoIn 1s cubic-bezier(.2,.7,.2,1) both;
  animation-delay: 2.0s;
}
.hero-logo .hero-tekst{
  width:min(82vw, 360px);
  height:auto;
  margin-top:8px;
  mix-blend-mode: darken;
  animation: logoIn 1s cubic-bezier(.2,.7,.2,1) both;
  animation-delay: 2.3s;
}
@keyframes logoIn{
  0%   { opacity:0; transform: scale(.9) translateY(18px); }
  100% { opacity:1; transform: scale(1)  translateY(0); }
}
.hero-logo .hero-desc{
  max-width:620px; margin:28px auto 0;
  animation: logoIn 1s ease-out both;
  animation-delay: 2.55s;
}
.hero-logo .hero-desc p{
  font-family:var(--f-body); font-size:17px;
  color:var(--ink-soft); line-height:1.6;
  margin:0 0 12px;
}
.hero-logo .hero-desc p:last-child{ margin-bottom:0; }
.hero-logo .hero-soon{
  margin-top:10px;
  font-family:var(--f-display); font-style:italic; font-size:22px;
  color:var(--bordo); font-weight:500;
}
.hero-logo .hero-cta{
  display:flex; gap:14px; flex-wrap:wrap; justify-content:center; margin-top:28px;
  animation: logoIn 1s ease-out both;
  animation-delay: 2.8s;
}

/* ---------- generic section ---------- */
.section{ padding:60px 0; }
.section.tint{ background:var(--cream-2); }
.sec-head{ text-align:center;margin-bottom:34px; }

/* ---------- Summer break block ---------- */
.summer{
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,.12) 0 6px, rgba(0,0,0,0) 6px 34px, rgba(255,255,255,.04) 34px 40px, rgba(0,0,0,0) 40px 68px),
    linear-gradient(180deg, var(--bordo-deep) 0%, var(--bordo) 50%, var(--bordo-2) 100%);
  color:var(--cream-2);
  border:1px solid rgba(216,180,99,.35);
  border-radius:6px;
  max-width:920px; margin:0 auto;
  overflow:hidden;
}
.summer-strip{
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:0;
  height:160px;
}
.summer-strip img{ width:100%; height:100%; object-fit:cover; opacity:.92; }
.summer-strip img + img{ border-left:2px solid var(--bordo-deep); }
.summer-text{ padding:30px 24px 32px; text-align:center; }
.summer-text .diamond{ display:block; margin:0 auto 14px; }
.summer-text h3{
  font-family:var(--f-display); font-weight:600; font-size:30px;
  color:var(--gold-2); margin:0 0 14px; line-height:1.15;
}
.summer-text p{ color:rgba(255,255,255,.82); font-size:17px; max-width:580px; margin:0 auto 10px; }
.summer-text .ps{ font-style:italic; font-family:var(--f-display); font-size:18px; color:var(--gold-2); margin-top:14px; }
.summer-text .btn{ margin-top:22px; border-color:var(--gold); color:var(--gold-2); }
.summer-text .btn:hover{ background:var(--gold); color:var(--bordo-deep); border-color:var(--gold); }
.summer.sm .summer-strip{ height:110px; }
.summer.sm .summer-text h3{ font-size:24px; }
.summer.plain .summer-text{ padding:42px 24px 44px; }

/* ---------- Repertoar grid ---------- */
.rep-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.rep{ position:relative;border-radius:4px;overflow:hidden;cursor:pointer;background:#1a1012;aspect-ratio:4/5; }
.rep img{ width:100%;height:100%;object-fit:cover;transition:.4s ease; }
.rep:hover img{ transform:scale(1.04); }
.rep .ov{ position:absolute;inset:0;background:linear-gradient(0deg, rgba(20,8,10,.92), rgba(20,8,10,.05) 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:18px;color:#fff; }
.rep .tag{ font-family:var(--f-ui);text-transform:uppercase;letter-spacing:.2em;font-size:10px;color:var(--gold-2); }
.rep .name{ font-family:var(--f-display);font-weight:600;font-size:22px;line-height:1.05;margin-top:4px; }
.rep .line{ font-size:13.5px;color:rgba(255,255,255,.75);margin-top:4px; }

/* ---------- Brojke (zavjesa pattern) ---------- */
.brojke{ position:relative;color:var(--cream-2);padding:64px 0 72px;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,.16) 0 6px, rgba(0,0,0,0) 6px 34px, rgba(255,255,255,.04) 34px 40px, rgba(0,0,0,0) 40px 68px),
    linear-gradient(180deg, var(--bordo-deep), var(--bordo) 30%, var(--bordo-2) 100%);
}
.brojke .row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px 16px;
  text-align:center;margin-top:34px;
}
.brojke .stat .num{ font-family:var(--f-display);font-weight:600;font-size:54px;line-height:1; }
.brojke .stat .num sup{ font-size:24px;color:var(--gold-2); }
.brojke .stat .lab{ font-family:var(--f-body);font-size:15px;color:rgba(255,255,255,.82);margin-top:6px;line-height:1.25; }
.brojke .stat .diamond{ margin:0 auto 14px; }

/* ---------- Novosti — "Pripremamo jesensku sezonu" ---------- */
.soon{
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,.12) 0 6px, rgba(0,0,0,0) 6px 34px, rgba(255,255,255,.04) 34px 40px, rgba(0,0,0,0) 40px 68px),
    linear-gradient(180deg, var(--bordo-deep), var(--bordo) 50%, var(--bordo-2));
  color:var(--cream-2);
  border:1px solid rgba(216,180,99,.35); border-radius:6px;
  padding:46px 24px 48px; text-align:center; max-width:720px; margin:0 auto;
}
.soon .diamond{ display:block; margin:0 auto 18px; width:14px; height:14px; }
.soon h3{
  font-family:var(--f-display); font-weight:600; font-size:38px;
  color:var(--gold-2); margin:0 0 14px; letter-spacing:.02em; line-height:1.1;
}
.soon p{ color:rgba(255,255,255,.82); font-size:17px; max-width:540px; margin:0 auto; }

/* ---------- Instagram band ---------- */
.insta-band{
  background:
    radial-gradient(120% 80% at 80% 0%, rgba(216,180,99,.16), transparent 55%),
    linear-gradient(180deg, var(--bordo) 0%, var(--bordo-deep) 100%);
  color:var(--cream-2); padding:54px 0;
}
.insta-band .ib{ text-align:center; max-width:640px; margin:0 auto; }
.insta-band h3{
  font-family:var(--f-display); font-weight:600; font-size:34px;
  margin:14px 0 12px; line-height:1.12;
}
.insta-band h3 em{ font-style:italic; color:var(--gold-2); }
.insta-band p{ color:rgba(255,255,255,.78); margin:0 0 22px; }

/* ---------- Footer ---------- */
.foot{ background:var(--cream); color:var(--ink); }
.foot .top{ display:grid;grid-template-columns:1fr;gap:30px;padding:50px 0 40px;align-items:start;text-align:center; }
.foot .flogo{ background:transparent;border:none;border-radius:0;padding:0;display:flex;align-items:center;justify-content:center;max-width:200px;margin:0 auto; }
.foot .flogo img{ height:auto;width:100%;max-width:160px; mix-blend-mode:darken; }
.foot h5{ font-family:var(--f-ui);text-transform:uppercase;letter-spacing:.2em;font-size:12.5px;font-weight:600;margin:0 0 16px;color:var(--bordo); }
.foot ul{ list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px; }
.foot ul li{ display:flex;gap:10px;align-items:center;justify-content:center;font-size:15.5px;color:var(--ink); }
.foot ul li .gt{ color:var(--gold); }
.foot ul li a{ display:flex;gap:10px;align-items:center; transition:opacity .15s; color:var(--ink); }
.foot ul li a:hover{ color:var(--bordo); }
.foot .soc-list a{ border-bottom:1px solid rgba(110,20,35,.25); padding-bottom:2px; }
.foot .bar{ background:var(--bordo); color:var(--cream-2); padding:18px 22px;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center;text-align:center;font-family:var(--f-ui);font-size:12px;letter-spacing:.06em; }
.foot .bar .soc{ display:flex;gap:22px; }
.foot .bar .soc a{ color:var(--cream-2); border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px; }

/* =====================================================================
   PAGE HERO band za podstranice
   ===================================================================== */
.page{ min-height:100vh; display:flex; flex-direction:column; }
.page .grow{ flex:1; }
.page-hero{ background:var(--bordo); color:var(--cream-2); padding:104px 0 48px; text-align:center; }
.page-hero h1{ font-family:var(--f-display); font-weight:600; font-size:40px; line-height:1.05; margin:14px 0 0; }
.page-hero h1 em{ font-style:italic; color:var(--gold-2); }
.page-hero .ph-sub{ font-family:var(--f-body); font-size:17px; color:rgba(255,255,255,.8); max-width:600px; margin:18px auto 0; }

/* ---------- PREDSTAVA detalj ---------- */
.detail{ display:grid; grid-template-columns:1fr; gap:30px; align-items:start; }
.detail .poster-col img{ width:100%; max-width:380px; margin:0 auto; border-radius:5px; box-shadow:0 18px 40px rgba(61,11,18,.22); }
.detail .tag{ font-family:var(--f-ui); text-transform:uppercase; letter-spacing:.2em; font-size:11px; color:var(--gold); }
.detail h2{ font-family:var(--f-display); font-weight:600; font-size:36px; line-height:1.02; color:var(--bordo); margin:10px 0 6px; }
.detail .perf{ font-family:var(--f-display); font-style:italic; font-size:20px; color:var(--ink-soft); }
.detail .blurb{ font-size:17px; line-height:1.65; margin:22px 0; }
.detail .facts{ display:flex; gap:24px; flex-wrap:wrap; margin:18px 0 26px; }
.detail .facts .f .k{ font-family:var(--f-ui); text-transform:uppercase; letter-spacing:.14em; font-size:10.5px; color:var(--ink-soft); }
.detail .facts .f .v{ font-family:var(--f-display); font-size:22px; color:var(--bordo); margin-top:4px; }

/* ---------- GALERIJA ---------- */
.gal{ columns:1; column-gap:14px; }
.gal .gal-btn{ display:block; margin:0 0 14px; break-inside:avoid; border-radius:4px; overflow:hidden; position:relative; border:0; padding:0; background:none; cursor:pointer; width:100%; }
.gal .gal-btn img{ width:100%; display:block; transition:.4s ease; }
.gal .gal-btn:hover img{ transform:scale(1.05); }
.gal .gal-btn::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(61,11,18,.4),transparent 50%); opacity:0; transition:.25s; }
.gal .gal-btn:hover::after{ opacity:1; }
/* lightbox */
.lbx{ position:fixed; inset:0; background:rgba(30,6,10,.94); z-index:9998; display:none; align-items:center; justify-content:center; padding:24px; }
.lbx.on{ display:flex; }
.lbx img{ max-width:94vw; max-height:88vh; border-radius:5px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lbx .x{ position:absolute; top:18px; right:22px; color:#fff; font-size:30px; cursor:pointer; font-family:var(--f-ui); }

/* ---------- O NAMA ---------- */
.about-lead{ display:grid; grid-template-columns:1fr; gap:30px; align-items:center; }
.about-lead .big{ font-family:var(--f-display); font-style:italic; font-weight:500; font-size:28px; line-height:1.2; color:var(--bordo); }
.about-lead p{ font-size:17px; line-height:1.65; color:var(--ink); margin:14px 0 0; }
.about-lead .collage{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.about-lead .collage img{ width:100%; aspect-ratio:3/4; object-fit:cover; border-radius:4px; }
.values{ display:grid; grid-template-columns:1fr; gap:24px; margin-top:10px; }
.value{ text-align:center; padding:8px; }
.value .di{ margin:0 auto 14px; }
.value h4{ font-family:var(--f-display); font-weight:600; font-size:24px; color:var(--bordo); margin:0 0 10px; }
.value p{ font-size:16px; color:var(--ink-soft); line-height:1.55; }

/* ---------- KONTAKT ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr; gap:36px; align-items:start; }
.contact-grid .ci{ margin-bottom:22px; }
.contact-grid .ci .k{ font-family:var(--f-ui); text-transform:uppercase; letter-spacing:.16em; font-size:11px; color:var(--ink-soft); }
.contact-grid .ci .v{ font-family:var(--f-display); font-size:23px; color:var(--bordo); margin-top:5px; }
.cform{ background:var(--cream-3); border:1px solid var(--line); border-radius:6px; padding:24px; }
.cform .fld{ margin-bottom:18px; }
.cform label{ display:block; font-family:var(--f-ui); text-transform:uppercase; letter-spacing:.14em; font-size:11px; color:var(--ink-soft); margin-bottom:8px; }
.cform input, .cform textarea, .cform select{ width:100%; background:#fff; border:1px solid var(--line); border-radius:3px;
  padding:12px 13px; font-family:var(--f-body); font-size:16px; color:var(--ink); }
.cform textarea{ min-height:120px; resize:vertical; }
.cform .btn{ width:100%; justify-content:center; margin-top:4px; }

/* (stari mobilni nav blok obrisan — sad je nav fiksan na vrhu na svim viewportima) */

/* =====================================================================
   TABLET (≥ 640px)
   ===================================================================== */
@media (min-width:640px){
  .ark{ font-size:17.5px; }
  .wrap{ padding:0 32px; }
  .section{ padding:78px 0; }
  .section-title{ font-size:42px; }
  .page-hero{ padding:114px 0 56px; }
  .page-hero h1{ font-size:52px; }
  .page-hero .ph-sub{ font-size:19px; max-width:640px; }

  .rep-grid{ grid-template-columns:1fr 1fr; gap:20px; }
  .summer-strip{ height:200px; }
  .summer-text h3{ font-size:36px; }

  .contact-grid{ grid-template-columns:1fr 1fr; gap:50px; }
  .about-lead{ grid-template-columns:1.1fr .9fr; gap:46px; }
  .about-lead .big{ font-size:34px; }
  .values{ grid-template-columns:1fr 1fr 1fr; }

  .detail{ grid-template-columns:.85fr 1.15fr; gap:48px; }
  .detail h2{ font-size:46px; }
  .detail .poster-col img{ max-width:none; }

  .gal{ columns:2; column-gap:16px; }
  .gal .gal-btn{ margin-bottom:16px; }

  .insta-band h3{ font-size:40px; }

  .brojke .stat .num{ font-size:64px; }
  .brojke .stat .lab{ font-size:16px; }

  .foot .top{
    grid-template-columns:1fr 1fr 1fr; gap:40px;
    padding:62px 0 48px; text-align:left;
  }
  .foot .top.two{ grid-template-columns:.8fr 1fr 1fr; }
  .foot .flogo{ margin:0; }
  .foot ul li, .foot ul li a{ justify-content:flex-start; }
  .foot .bar{ flex-direction:row; gap:24px; }
}

/* =====================================================================
   DESKTOP (≥ 980px)
   ===================================================================== */
@media (min-width:980px){
  .wrap{ padding:0 40px; }
  .ark{ font-size:18px; }
  .section{ padding:88px 0; }
  .section-title{ font-size:46px; }
  .sec-head{ margin-bottom:42px; }

  .nav{ padding:12px 32px; }

  .hero-logo{ min-height:92vh; padding-top:80px; }
  .hero-logo .hero-kapa{ width:min(260px, 24vw); }
  .hero-logo .hero-tekst{ width:min(420px, 36vw); }

  .rep-grid{ grid-template-columns:repeat(3,1fr); gap:26px; }
  .rep-grid.full{ grid-template-columns:repeat(3,1fr); }

  .brojke .row{ grid-template-columns:repeat(4,1fr); gap:20px; }
  .brojke .stat .num{ font-size:80px; }

  .page-hero{ padding:118px 0 60px; }
  .page-hero h1{ font-size:62px; }

  .gal{ columns:3; }
}

/* =====================================================================
   WIDER (≥ 1200px)
   ===================================================================== */
@media (min-width:1200px){
  .rep-grid.full{ grid-template-columns:repeat(4,1fr); }
}
