/* =====================================================================
   DAV — Keramika & Ugradnja vrata | Srebrenik
   Dizajn & razvoj: NoLimitDigital.io
   Koncept: "Fuga" — precizna mreža fuga (keramika) + okvir (vrata)
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Boje */
  --ink:#14171b;          /* tamni grafit / fuga */
  --ink-2:#1b1f25;        /* podignuta tamna ploha */
  --ink-3:#23282f;        /* kartice na tamnom */
  --biscuit:#ece4d6;      /* topli biskvit / nepečena keramika */
  --biscuit-2:#f5f0e6;    /* svjetlija ploha */
  --paper:#fbf9f4;        /* skoro bijela */
  --brass:#c39a57;        /* antikni mesing — primarni akcent */
  --brass-deep:#9b7636;
  --brass-soft:#d8b87f;
  --glaze:#27564f;        /* duboka glazura tirkiz — sekundarni akcent */
  --glaze-light:#3a7d72;
  --stone:#6b7079;        /* prigušeni tekst */
  --stone-2:#8c9098;
  --line:rgba(20,23,27,.12);
  --line-light:rgba(236,228,214,.14);

  /* Tipografija */
  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Schibsted Grotesk",system-ui,-apple-system,Segoe UI,sans-serif;
  --f-mono:"Space Mono","SFMono-Regular",Menlo,monospace;

  /* Mjere */
  --wrap:1240px;
  --gut:clamp(20px,5vw,72px);
  --radius:3px;             /* keramika = oštri, precizni rubovi */
  --shadow:0 1px 2px rgba(20,23,27,.06),0 14px 40px -18px rgba(20,23,27,.28);
  --shadow-lift:0 2px 4px rgba(20,23,27,.08),0 30px 60px -24px rgba(20,23,27,.42);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,17.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
ul{list-style:none;padding:0}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:2px}

/* ---------- Tipografski sistem ---------- */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:380;line-height:1.04;letter-spacing:-.015em}
h1{font-size:clamp(2.6rem,6.4vw,5.4rem)}
h2{font-size:clamp(2rem,4.4vw,3.5rem)}
h3{font-size:clamp(1.3rem,2.3vw,1.85rem);letter-spacing:-.01em}
.display-italic{font-style:italic;font-optical-sizing:auto}
.eyebrow{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--brass-deep);font-weight:700;
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass)}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--brass)}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--stone);max-width:56ch}
.mono{font-family:var(--f-mono);letter-spacing:.02em}

/* ---------- Layout ---------- */
.wrap{width:min(100% - 2*var(--gut),var(--wrap));margin-inline:auto}
.section{padding-block:clamp(64px,9vw,140px);position:relative}
.section--tight{padding-block:clamp(48px,6vw,90px)}
.bg-ink{background:var(--ink);color:var(--biscuit)}
.bg-biscuit{background:var(--biscuit)}
.bg-glaze{background:var(--glaze);color:var(--biscuit-2)}
.center{text-align:center}
.center .lead{margin-inline:auto}

/* Fuga-linija razdjelnik */
.grout-rule{height:1px;background:var(--line);position:relative;overflow:hidden}
.bg-ink .grout-rule{background:var(--line-light)}
.grout-rule::after{content:"";position:absolute;inset:0;width:0;background:var(--brass);transition:width 1.1s var(--ease)}
.grout-rule.is-in::after{width:100%}

/* ---------- Dugmad ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--f-body);font-weight:600;font-size:.96rem;letter-spacing:.01em;
  padding:.95em 1.6em;border-radius:var(--radius);
  position:relative;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease);
  will-change:transform;
}
.btn svg{width:1.05em;height:1.05em;transition:transform .3s var(--ease)}
.btn--primary{background:var(--brass);color:var(--ink)}
.btn--primary:hover{background:var(--brass-soft);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(195,154,87,.65)}
.btn--primary:hover svg{transform:translateX(4px)}
.btn--ghost{border:1px solid var(--line);color:var(--ink)}
.bg-ink .btn--ghost,.btn--ghost.on-dark{border-color:var(--line-light);color:var(--biscuit)}
.btn--ghost:hover{border-color:var(--brass);color:var(--brass-deep);transform:translateY(-2px)}
.bg-ink .btn--ghost:hover{color:var(--brass-soft)}
.btn--glaze{background:var(--glaze);color:var(--biscuit-2)}
.btn--glaze:hover{background:var(--glaze-light);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(39,86,79,.6)}
.btn--lg{padding:1.1em 2em;font-size:1.02rem}

/* ====================================================================
   TOP BAR
   ==================================================================== */
.topbar{background:var(--ink);color:var(--biscuit);font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:1rem}
.topbar a{color:var(--biscuit);opacity:.8;transition:opacity .2s,color .2s}
.topbar a:hover{opacity:1;color:var(--brass-soft)}
.topbar__left,.topbar__right{display:flex;align-items:center;gap:1.4rem}
.topbar__item{display:inline-flex;align-items:center;gap:.45em;font-family:var(--f-mono);letter-spacing:.02em}
.topbar__item svg{width:14px;height:14px;color:var(--brass)}
@media (max-width:760px){.topbar__hideMobile{display:none}}

/* ====================================================================
   HEADER / NAV
   ==================================================================== */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(251,249,244,.86);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.is-stuck{border-color:var(--line);box-shadow:0 10px 30px -22px rgba(20,23,27,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand__mark{width:42px;height:42px;flex-shrink:0}
.brand__name{font-family:var(--f-display);font-size:1.4rem;letter-spacing:-.01em;line-height:1}
.brand__name b{color:var(--brass-deep);font-weight:500}
.brand__sub{display:block;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:var(--stone);margin-top:3px}

.nav__links{display:flex;align-items:center;gap:.3rem}
.nav__link{
  display:inline-flex;align-items:center;gap:.4em;padding:.6em .9em;border-radius:var(--radius);
  font-weight:500;font-size:.97rem;color:var(--ink);position:relative;transition:color .2s;
}
.nav__link::after{content:"";position:absolute;left:.9em;right:.9em;bottom:.45em;height:1px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav__link:hover,.nav__link[aria-current="page"]{color:var(--brass-deep)}
.nav__link:hover::after,.nav__link[aria-current="page"]::after{transform:scaleX(1)}
.nav__link svg{width:.7em;height:.7em;transition:transform .3s var(--ease)}
.nav__cta{margin-left:.6rem}

/* Mega dropdown — stilizovan kao keramičke pločice */
.has-mega{position:relative}
.mega{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);
  width:min(640px,90vw);background:var(--paper);border:1px solid var(--line);border-radius:6px;
  box-shadow:var(--shadow-lift);padding:10px;
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;
  z-index:70;
}
.mega::before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:var(--paper);border-left:1px solid var(--line);border-top:1px solid var(--line)}
.mega::after{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.has-mega:hover .mega,.has-mega:focus-within .mega,.mega.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega__head{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;padding:6px 10px 2px}
.mega__head .eyebrow{font-size:.66rem}
.mega__tile{
  display:flex;gap:.85rem;align-items:flex-start;padding:14px;border-radius:var(--radius);
  background:var(--biscuit-2);border:1px solid transparent;transition:background .22s,border-color .22s,transform .22s var(--ease);
  position:relative;overflow:hidden;
}
.mega__tile::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brass);transform:scaleY(0);transform-origin:top;transition:transform .25s var(--ease)}
.mega__tile:hover{background:var(--paper);border-color:var(--line);transform:translateY(-1px)}
.mega__tile:hover::after{transform:scaleY(1)}
.mega__tile.glaze::after{background:var(--glaze)}
.mega__ic{width:38px;height:38px;flex-shrink:0;border-radius:var(--radius);display:grid;place-items:center;background:var(--ink);color:var(--brass)}
.mega__tile.glaze .mega__ic{background:var(--glaze);color:var(--biscuit-2)}
.mega__ic svg{width:20px;height:20px}
.mega__tl{display:block;font-family:var(--f-body);font-weight:600;font-size:.97rem;letter-spacing:-.005em;line-height:1.2}
.mega__ds{display:block;font-size:.82rem;color:var(--stone);margin-top:2px;line-height:1.4}
.mega__foot{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;padding:8px 12px 4px;font-size:.85rem;color:var(--stone)}
.mega__foot a{color:var(--brass-deep);font-weight:600}

/* Hamburger / mobilni meni */
.nav__toggle{display:none;width:44px;height:44px;border-radius:var(--radius);align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__toggle span{width:22px;height:2px;background:var(--ink);transition:transform .3s var(--ease),opacity .2s}
.nav__toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.is-open span:nth-child(2){opacity:0}
.nav__toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:980px){
  /* Bez backdrop-filtera na mobilnom: inace fixed meni ostaje "zarobljen" u headeru */
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--paper)}
  .nav__cta.desktop{display:none}
  .nav__toggle{display:flex;position:relative;z-index:66}
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(420px,86vw);background:var(--paper);
    flex-direction:column;align-items:stretch;gap:0;padding:90px 24px 32px;
    transform:translateX(100%);transition:transform .4s var(--ease);box-shadow:var(--shadow-lift);
    overflow-y:auto;z-index:65;
  }
  .nav__links.is-open{transform:translateX(0)}
  .nav__link{padding:1em .4em;font-size:1.1rem;border-bottom:1px solid var(--line)}
  .nav__link::after{display:none}
  .nav__link svg{margin-left:auto}
  .nav__cta.desktop{display:none}
  .mega{
    position:static;transform:none;width:auto;box-shadow:none;border:none;opacity:1;visibility:visible;
    pointer-events:auto;grid-template-columns:1fr;padding:4px 0 12px;background:transparent;
    max-height:0;overflow:hidden;transition:max-height .35s var(--ease);
  }
  .mega::before{display:none}
  .mega::after{display:none}
  /* na dodir :hover ostane zalijepljen -> ponisti desktop pomak translateX(-50%) */
  .has-mega:hover .mega,.has-mega:focus-within .mega,.has-mega.is-open .mega,.mega.is-open{transform:none}
  .has-mega.is-open .mega{max-height:900px}
  .mega__head,.mega__foot{display:none}
  .mega__tile{background:var(--biscuit-2)}
  .nav-backdrop{position:fixed;inset:0;background:rgba(20,23,27,.45);opacity:0;visibility:hidden;transition:opacity .3s;z-index:64}
  .nav-backdrop.is-open{opacity:1;visibility:visible}
}

/* ====================================================================
   HERO
   ==================================================================== */
.hero{position:relative;background:var(--ink);color:var(--biscuit);overflow:hidden;isolation:isolate}
.hero__grid-bg{position:absolute;inset:0;z-index:-2;opacity:.5}
.hero__glow{position:absolute;width:60vw;height:60vw;right:-15vw;top:-20vw;background:radial-gradient(circle,rgba(195,154,87,.16),transparent 62%);z-index:-1;pointer-events:none}
.hero__glow2{position:absolute;width:50vw;height:50vw;left:-18vw;bottom:-22vw;background:radial-gradient(circle,rgba(39,86,79,.28),transparent 60%);z-index:-1;pointer-events:none}
.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,72px);align-items:center;padding-block:clamp(60px,9vw,120px);min-height:min(86vh,820px)}
.hero__loc{margin-bottom:1.4rem}
.hero h1{color:var(--biscuit-2);margin-bottom:1.4rem}
.hero h1 em{color:var(--brass);font-style:italic}
.hero__lead{color:rgba(236,228,214,.78);max-width:46ch;margin-bottom:2.2rem;font-size:clamp(1.05rem,1.55vw,1.24rem)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:2.6rem}
.hero__meta{display:flex;gap:clamp(1.4rem,3vw,2.6rem);flex-wrap:wrap;padding-top:1.8rem;border-top:1px solid var(--line-light)}
.hero__metaItem .n{font-family:var(--f-display);font-size:clamp(1.7rem,3vw,2.4rem);color:var(--brass);line-height:1;display:block}
.hero__metaItem .l{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-2);margin-top:.5rem;display:block}

/* Hero vizual — "vrata + pločice" okvir s animacijom polaganja */
.hero__art{position:relative;aspect-ratio:4/5;max-width:440px;width:100%;margin-inline:auto}
.hero__frame{position:absolute;inset:0;border:2px solid var(--brass);border-radius:4px}
.hero__frame::before{content:"";position:absolute;inset:14px;border:1px solid rgba(195,154,87,.4)}
.hero__door{position:absolute;inset:24px;background:linear-gradient(160deg,#202730,#171c22);border-radius:2px;box-shadow:inset 0 0 0 1px rgba(236,228,214,.06)}
.hero__handle{position:absolute;right:46px;top:50%;width:8px;height:46px;border-radius:6px;background:var(--brass);box-shadow:0 0 14px rgba(195,154,87,.5)}
.hero__tiles{position:absolute;inset:24px;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(5,1fr);gap:3px;padding:0;overflow:hidden;border-radius:2px}
.hero__tiles .t{background:linear-gradient(150deg,#2a313a,#1d232b);opacity:0;transform:scale(.82);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.hero__tiles .t.lit{background:linear-gradient(150deg,var(--brass-deep),#7c5d2a)}
.hero__tiles .t.glz{background:linear-gradient(150deg,var(--glaze-light),var(--glaze))}
.hero__art.is-in .t{opacity:1;transform:scale(1)}
.hero__badge{position:absolute;left:-18px;bottom:34px;background:var(--biscuit);color:var(--ink);padding:.85rem 1.1rem;border-radius:var(--radius);box-shadow:var(--shadow-lift);display:flex;align-items:center;gap:.7rem;font-size:.86rem}
.hero__badge svg{width:30px;height:30px;color:var(--glaze)}
.hero__badge b{display:block;font-family:var(--f-display);font-size:1.05rem}
.hero__badge span{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone)}
.hero__scroll{position:absolute;left:var(--gut);bottom:24px;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone-2);display:flex;align-items:center;gap:.6em}
.hero__scroll i{width:1px;height:30px;background:linear-gradient(var(--brass),transparent);display:block;animation:scrolldrop 1.8s var(--ease) infinite}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media (max-width:880px){
  .hero__inner{grid-template-columns:1fr;text-align:left}
  .hero__art{grid-row:1;max-width:300px;margin-bottom:1rem}
  .hero__scroll{display:none}
}

/* ====================================================================
   LOGO / TRUST STRIP
   ==================================================================== */
.marquee{border-block:1px solid var(--line);background:var(--biscuit-2);overflow:hidden}
.marquee__row{display:flex;gap:3.2rem;padding-block:18px;width:max-content;animation:slide 34s linear infinite}
.marquee:hover .marquee__row{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.marquee__item{display:inline-flex;align-items:center;gap:.6em;font-family:var(--f-mono);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);white-space:nowrap}
.marquee__item svg{width:16px;height:16px;color:var(--brass)}
@media (prefers-reduced-motion:reduce){.marquee__row{animation:none;flex-wrap:wrap;width:auto;justify-content:center}}

/* ====================================================================
   SECTION HEAD
   ==================================================================== */
.sec-head{max-width:62ch}
.sec-head--center{margin-inline:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:1.1rem}
.sec-head h2{margin-bottom:1.1rem}
.sec-head h2 em{font-style:italic;color:var(--brass-deep)}
.bg-ink .sec-head h2 em{color:var(--brass)}

/* ====================================================================
   USLUGE (tile grid)
   ==================================================================== */
.svc-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.4vw,28px);margin-top:clamp(36px,5vw,60px)}
@media (max-width:780px){.svc-split{grid-template-columns:1fr}}
.svc-col{background:var(--biscuit-2);border:1px solid var(--line);border-radius:6px;padding:clamp(24px,3vw,40px);position:relative;overflow:hidden}
.svc-col--glaze{background:var(--glaze);color:var(--biscuit-2)}
.svc-col__tag{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:1.1rem}
.svc-col--glaze .svc-col__tag{color:var(--brass-soft)}
.svc-col h3{margin-bottom:.7rem}
.svc-col__lead{color:var(--stone);margin-bottom:1.6rem;font-size:.98rem}
.svc-col--glaze .svc-col__lead{color:rgba(236,228,214,.8)}
.svc-list{display:grid;gap:2px}
.svc-item{
  display:flex;align-items:center;gap:.9rem;padding:.9rem 1rem;border-radius:var(--radius);
  background:var(--paper);transition:transform .22s var(--ease),box-shadow .22s var(--ease);
}
.svc-col--glaze .svc-item{background:rgba(20,23,27,.22)}
.svc-item:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.svc-item__ic{width:34px;height:34px;border-radius:var(--radius);background:var(--ink);color:var(--brass);display:grid;place-items:center;flex-shrink:0}
.svc-col--glaze .svc-item__ic{background:var(--biscuit-2);color:var(--glaze)}
.svc-item__ic svg{width:18px;height:18px}
.svc-item__tl{display:block;font-weight:600;font-size:.96rem}
.svc-item__ds{display:block;font-size:.8rem;color:var(--stone);margin-top:1px}
.svc-col--glaze .svc-item__ds{color:rgba(236,228,214,.6)}
.svc-item__ar{margin-left:auto;color:var(--brass);opacity:0;transform:translateX(-6px);transition:.22s var(--ease)}
.svc-item:hover .svc-item__ar{opacity:1;transform:translateX(0)}
.svc-col__foot{margin-top:1.8rem}

/* ====================================================================
   PROCES (numbered grout steps)
   ==================================================================== */
.proc{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:clamp(40px,5vw,64px);position:relative}
.proc__line{position:absolute;top:34px;left:6%;right:6%;height:1px;background:var(--line-light)}
.bg-biscuit .proc__line{background:var(--line)}
.proc__step{padding:0 clamp(8px,1.4vw,18px);position:relative}
.proc__num{
  width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin-bottom:1.4rem;
  font-family:var(--f-display);font-size:1.5rem;background:var(--ink-2);color:var(--brass);
  border:1px solid var(--line-light);position:relative;z-index:1;
}
.bg-biscuit .proc__num{background:var(--paper);border-color:var(--line);box-shadow:var(--shadow)}
.proc__step h4{font-family:var(--f-body);font-weight:600;font-size:1.02rem;margin-bottom:.4rem}
.proc__step p{font-size:.86rem;color:var(--stone)}
.bg-ink .proc__step p{color:rgba(236,228,214,.62)}
@media (max-width:860px){
  .proc{grid-template-columns:1fr 1fr;gap:28px 16px}
  .proc__line{display:none}
}
@media (max-width:480px){.proc{grid-template-columns:1fr}}

/* ====================================================================
   GALERIJA
   ==================================================================== */
.gal-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem;margin-bottom:2.2rem}
.gal-filter button{
  font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.6em 1.1em;border-radius:40px;border:1px solid var(--line);color:var(--stone);transition:.2s var(--ease);
}
.gal-filter button:hover{border-color:var(--brass);color:var(--brass-deep)}
.gal-filter button.is-active{background:var(--ink);color:var(--brass);border-color:var(--ink)}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;grid-auto-flow:dense}
.gal-card{
  position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;
  background:var(--ink-3);box-shadow:var(--shadow);cursor:pointer;
}
.gal-card.tall{aspect-ratio:4/5;grid-row:span 1}
.gal-card.wide{grid-column:span 2}
@media (max-width:560px){.gal-card.wide{grid-column:span 1}}
.gal-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gal-card__ph{width:100%;height:100%;display:grid;place-items:center;background:
  repeating-linear-gradient(45deg,#262c34 0 14px,#222831 14px 28px)}
.gal-card__ph svg{width:46px;height:46px;color:rgba(195,154,87,.4)}
.gal-card:hover img{transform:scale(1.06)}
.gal-card__ov{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:18px;
  background:linear-gradient(transparent 40%,rgba(20,23,27,.82));opacity:0;transition:opacity .3s var(--ease);
}
.gal-card:hover .gal-card__ov,.gal-card:focus-within .gal-card__ov{opacity:1}
.gal-card__cat{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-soft)}
.gal-card__tl{font-family:var(--f-display);color:var(--biscuit-2);font-size:1.15rem;margin-top:.2rem}

/* ====================================================================
   ZAŠTO MI / GARANCIJA
   ==================================================================== */
.why{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(20px,2.4vw,34px);margin-top:clamp(40px,5vw,60px)}
.why__card{padding:clamp(22px,2.6vw,32px);border-top:2px solid var(--brass);background:var(--biscuit-2);border-radius:0 0 var(--radius) var(--radius);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.bg-ink .why__card{background:var(--ink-2);border-top-color:var(--brass)}
.why__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.why__ic{width:48px;height:48px;color:var(--brass);margin-bottom:1.2rem}
.why__card h3{font-size:1.25rem;margin-bottom:.6rem}
.why__card p{font-size:.92rem;color:var(--stone)}
.bg-ink .why__card p{color:rgba(236,228,214,.66)}

/* ====================================================================
   STATS / BROJAČ
   ==================================================================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,24px);margin-top:clamp(40px,5vw,56px)}
@media (max-width:680px){.stats{grid-template-columns:1fr 1fr}}
.stat{text-align:center;padding:clamp(20px,2.4vw,32px) 12px;border:1px solid var(--line-light);border-radius:var(--radius)}
.stat .n{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--brass);line-height:1}
.stat .l{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-2);margin-top:.7rem}

/* ====================================================================
   RECENZIJE
   ==================================================================== */
.revs{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(16px,2vw,24px);margin-top:clamp(40px,5vw,56px)}
.rev{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:clamp(24px,2.6vw,32px);position:relative}
.rev__q{font-family:var(--f-display);font-size:3.2rem;line-height:.5;color:var(--brass);opacity:.4;height:.5em}
.rev p{font-size:1rem;margin:1rem 0 1.4rem;color:var(--ink)}
.rev__who{display:flex;align-items:center;gap:.8rem}
.rev__av{width:42px;height:42px;border-radius:50%;background:var(--glaze);color:var(--biscuit-2);display:grid;place-items:center;font-family:var(--f-display);font-size:1.1rem}
.rev__name{font-weight:600;font-size:.94rem}
.rev__loc{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--stone)}
.rev__stars{color:var(--brass);font-size:.85rem;letter-spacing:.1em;margin-top:.2rem}

/* ====================================================================
   CTA BAND
   ==================================================================== */
.cta-band{position:relative;overflow:hidden}
.cta-band__inner{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,4vw,60px);align-items:center}
@media (max-width:780px){.cta-band__inner{grid-template-columns:1fr}}
.cta-band h2{color:var(--biscuit-2)}
.cta-band h2 em{font-style:italic;color:var(--brass)}
.cta-band p{color:rgba(236,228,214,.74);margin-top:1rem;max-width:48ch}
.cta-band__actions{display:flex;flex-direction:column;gap:1rem}
.cta-band__phone{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem;border:1px solid var(--line-light);border-radius:var(--radius);transition:border-color .3s,transform .3s}
.cta-band__phone:hover{border-color:var(--brass);transform:translateY(-2px)}
.cta-band__phone svg{width:40px;height:40px;color:var(--brass)}
.cta-band__phone .s{display:block;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-2);margin-bottom:3px}
.cta-band__phone .n{display:block;font-family:var(--f-display);font-size:1.5rem;line-height:1.05;color:var(--biscuit-2)}

/* ====================================================================
   KONTAKT
   ==================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);margin-top:clamp(36px,4vw,56px)}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-bottom:.5rem}
.field input,.field textarea,.field select{
  width:100%;padding:.95em 1.05em;border:1px solid var(--line);border-radius:var(--radius);
  font:inherit;background:var(--paper);color:var(--ink);transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(195,154,87,.16)}
.field textarea{resize:vertical;min-height:130px}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:2.8rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239b7636' stroke-width='2.4'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1.05rem center}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:520px){.field-row{grid-template-columns:1fr}}
.contact-aside{background:var(--ink);color:var(--biscuit);border-radius:6px;padding:clamp(26px,3vw,40px)}
.contact-aside h3{color:var(--biscuit-2);margin-bottom:1.6rem}
.ci{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line-light)}
.ci>span:last-child{flex:1;min-width:0}
.ci:last-of-type{border-bottom:none}
.ci__ic{width:42px;height:42px;border-radius:var(--radius);background:var(--ink-3);color:var(--brass);display:grid;place-items:center;flex-shrink:0}
.ci__ic svg{width:20px;height:20px}
.ci__l{display:block;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone-2)}
.ci__v{display:block;font-size:1.02rem;color:var(--biscuit-2);margin-top:.25rem}
.ci__v a:hover{color:var(--brass-soft)}
.contact-socials{display:flex;gap:.7rem;margin-top:1.6rem}
.contact-socials a{width:42px;height:42px;border-radius:var(--radius);border:1px solid var(--line-light);display:grid;place-items:center;color:var(--biscuit);transition:.2s}
.contact-socials a:hover{border-color:var(--brass);color:var(--brass);transform:translateY(-2px)}
.contact-socials svg{width:20px;height:20px}

/* ====================================================================
   FOOTER
   ==================================================================== */
.site-footer{background:var(--ink);color:var(--biscuit);padding-top:clamp(56px,7vw,90px)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(24px,3vw,48px);padding-bottom:clamp(40px,5vw,60px)}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand .brand__name{color:var(--biscuit-2)}
.foot-brand p{color:rgba(236,228,214,.6);font-size:.9rem;margin-top:1.2rem;max-width:34ch}
.foot-col h5{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:1.2rem}
.foot-col a,.foot-col li{display:block;color:rgba(236,228,214,.72);font-size:.92rem;padding:.35rem 0;transition:color .2s,padding-left .2s}
.foot-col a:hover{color:var(--brass-soft);padding-left:5px}
.foot-bottom{border-top:1px solid var(--line-light);padding-block:24px;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:var(--stone-2)}
.foot-bottom .mono{font-family:var(--f-mono)}
.foot-bottom a{color:var(--brass-soft)}
.foot-credit a{font-weight:600}

/* ====================================================================
   SCROLL REVEAL
   ==================================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__tiles .t{opacity:1;transform:none}
  .hero__scroll i{animation:none}
  .hero__tiles::after,.hero__art .t.lit,.hero__art .t.glz,.hero__handle{animation:none!important}
}

/* ====================================================================
   PAGE HERO (unutrašnje stranice)
   ==================================================================== */
.page-hero{background:var(--ink);color:var(--biscuit);padding-block:clamp(60px,8vw,120px);position:relative;overflow:hidden}
.page-hero__glow{position:absolute;width:50vw;height:50vw;right:-12vw;top:-16vw;background:radial-gradient(circle,rgba(195,154,87,.14),transparent 62%);pointer-events:none}
.page-hero .crumbs{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--stone-2);margin-bottom:1.4rem;display:flex;gap:.6em;align-items:center}
.page-hero .crumbs a:hover{color:var(--brass-soft)}
.page-hero h1{color:var(--biscuit-2);max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--brass)}
.page-hero p{color:rgba(236,228,214,.74);max-width:54ch;margin-top:1.3rem;font-size:1.1rem}

/* Prose za info stranice */
.prose{max-width:68ch}
.prose p{margin-bottom:1.2rem;color:var(--ink)}
.prose h3{margin:2.2rem 0 .8rem}
.prose ul.ticks{display:grid;gap:.7rem;margin:1.2rem 0}
.prose ul.ticks li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink)}
.prose ul.ticks svg{width:20px;height:20px;color:var(--glaze);flex-shrink:0;margin-top:3px}

/* dvije kolone info + slika */
.split2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
@media (max-width:820px){.split2{grid-template-columns:1fr}}
.split2__media{aspect-ratio:4/3;border-radius:6px;overflow:hidden;background:
  repeating-linear-gradient(45deg,#262c34 0 16px,#222831 16px 32px);position:relative;box-shadow:var(--shadow-lift)}
.split2__media svg{position:absolute;inset:0;margin:auto;width:60px;height:60px;color:rgba(195,154,87,.4)}

/* utility */
.mt-0{margin-top:0}.flow>*+*{margin-top:1rem}
.hide{display:none!important}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--biscuit-2);padding:1rem 1.4rem;border-radius:var(--radius);box-shadow:var(--shadow-lift);opacity:0;transition:.3s var(--ease);z-index:200;border-left:3px solid var(--brass)}
.toast.is-on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ====================================================================
   HERO — živa animacija mozaika (keramika + vrata)
   ==================================================================== */
.hero__tiles .t{transition:opacity .5s var(--ease),transform .5s var(--ease),background .7s var(--ease),filter .5s var(--ease)}

/* odsjaj glazure koji prelazi preko pločica */
.hero__tiles::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(125deg,transparent 38%,rgba(236,228,214,.10) 47%,rgba(195,154,87,.20) 50%,rgba(236,228,214,.08) 53%,transparent 62%);
  transform:translateX(-130%);
}
.hero__art.is-in .hero__tiles::after{animation:heroSheen 7s ease-in-out 1.6s infinite}
@keyframes heroSheen{0%{transform:translateX(-130%)}55%,100%{transform:translateX(130%)}}

/* blago pulsiranje akcentnih (brass/glaze) pločica */
.hero__art.is-in .t.lit{animation:tileGlow 4.6s ease-in-out infinite}
.hero__art.is-in .t.glz{animation:tileGlow 5.8s ease-in-out .9s infinite}
@keyframes tileGlow{0%,100%{filter:brightness(1)}50%{filter:brightness(1.3)}}

/* sjaj kvake na vratima */
.hero__art.is-in .hero__handle{animation:handleGlow 3.6s ease-in-out infinite}
@keyframes handleGlow{0%,100%{box-shadow:0 0 14px rgba(195,154,87,.5)}50%{box-shadow:0 0 24px rgba(195,154,87,.9)}}

/* pojedinačno "polaganje" pločice — okida JS */
.hero__tiles .t.relay{animation:tileRelay .85s var(--ease)}
@keyframes tileRelay{0%{transform:scale(1);filter:brightness(1)}28%{transform:scale(.88);filter:brightness(1.55)}100%{transform:scale(1);filter:brightness(1)}}

/* ====================================================================
   Premium scrollbar (u stilu stranice)
   ==================================================================== */
html{scrollbar-width:thin;scrollbar-color:var(--brass-deep) var(--biscuit-2)}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:var(--biscuit-2)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--brass),var(--brass-deep));border-radius:10px;border:3px solid var(--biscuit-2)}
::-webkit-scrollbar-thumb:hover{background:var(--brass-deep)}
::-webkit-scrollbar-corner{background:var(--biscuit-2)}

/* ====================================================================
   Custom dropdown (zamjena native <select> izgleda) — u stilu stranice
   ==================================================================== */
.csel{position:relative;width:100%}
.csel__btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:.8rem;
  padding:.95em 1.05em;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--paper);color:var(--ink);font:inherit;cursor:pointer;text-align:left;
  transition:border-color .2s,box-shadow .2s;
}
.csel__btn:focus-visible{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(195,154,87,.16)}
.csel.is-open .csel__btn{border-color:var(--brass);box-shadow:0 0 0 3px rgba(195,154,87,.16)}
.csel__btn[data-placeholder="1"]{color:var(--stone)}
.csel__btn svg{width:14px;height:14px;color:var(--brass-deep);transition:transform .25s var(--ease);flex-shrink:0}
.csel.is-open .csel__btn svg{transform:rotate(180deg)}
.csel__list{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:40;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-lift);padding:.4rem;margin:0;list-style:none;
  max-height:260px;overflow-y:auto;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s;
}
.csel.is-open .csel__list{opacity:1;visibility:visible;transform:translateY(0)}
.csel__opt{
  padding:.7em .85em;border-radius:var(--radius);cursor:pointer;font-size:.97rem;color:var(--ink);
  transition:background .15s,color .15s;
}
.csel__opt:hover,.csel__opt.is-active{background:var(--biscuit);color:var(--brass-deep)}
.csel__opt[aria-selected="true"]{font-weight:600;color:var(--brass-deep)}
.csel__list::-webkit-scrollbar{width:8px}
.csel__list::-webkit-scrollbar-thumb{background:var(--brass-deep);border-radius:8px;border:2px solid var(--paper)}

/* ====================================================================
   Mobilni meni — ispravan stacking (backdrop ISPOD headera) + razmaci
   Drawer je unutar <header> (z-index:60); zato backdrop mora biti < 60
   da ne prekrije i ne zatamni panel.
   ==================================================================== */
@media (max-width:980px){
  .site-header{z-index:60}
  .nav-backdrop{z-index:55}            /* ispod headera -> ne tamni panel */
  .nav__links{z-index:65;background:var(--paper)}
  .nav__toggle{margin-left:auto;z-index:66;position:relative}
  /* burger/X da ne lijepe uz ivicu ekrana */
  .nav.wrap{padding-right:6px}
}

/* ====================================================================
   Responsive dotjerivanje — manji telefoni
   ==================================================================== */
@media (max-width:600px){
  :root{--gut:18px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%;justify-content:center}
  .hero__meta{gap:1.4rem;flex-wrap:wrap}
  .cta-band__phone{padding:1rem 1.1rem}
  .btn--lg{width:100%;justify-content:center}
}
@media (max-width:420px){
  :root{--gut:14px}
  h1{font-size:clamp(2.1rem,9vw,2.8rem)}
  .nav__links{width:min(360px,92vw);padding:84px 20px 28px}
  .brand__name{font-size:1.2rem}
  .brand__sub{font-size:.52rem;letter-spacing:.2em}
  .mega__tl{font-size:.92rem}
  .field-row{grid-template-columns:1fr}
}

/* ====================================================================
   Footer pravni linkovi + traka za kolačiće
   ==================================================================== */
.foot-legal{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2.2rem;padding-top:1.6rem;border-top:1px solid var(--line-light)}
.foot-legal a{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.06em;color:var(--stone-2);transition:color .2s}
.foot-legal a:hover{color:var(--brass-soft)}

.cookie{position:fixed;left:0;right:0;bottom:0;z-index:90;padding:0 clamp(14px,4vw,28px) clamp(14px,3vw,24px);
  transform:translateY(140%);transition:transform .5s var(--ease)}
.cookie.is-in{transform:translateY(0)}
.cookie__in{max-width:880px;margin:0 auto;background:var(--ink-2);color:var(--biscuit);
  border:1px solid var(--line-light);border-radius:8px;box-shadow:var(--shadow-lift);
  padding:clamp(16px,2.4vw,22px) clamp(18px,2.6vw,26px);
  display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;justify-content:space-between}
.cookie__txt{font-size:.92rem;color:rgba(236,228,214,.82);max-width:54ch;margin:0}
.cookie__txt a{color:var(--brass-soft);text-decoration:underline;text-underline-offset:2px}
.cookie__btns{display:flex;gap:.7rem;flex-shrink:0}
.cookie__btns .btn{padding:.7em 1.1em;font-size:.85rem}
@media (max-width:600px){
  .cookie__in{flex-direction:column;align-items:stretch;gap:1rem}
  .cookie__btns{justify-content:stretch}
  .cookie__btns .btn{flex:1;justify-content:center}
}
