/* ============================================================================
   HOMEPAGE sections — Čarman
   ============================================================================ */

/* ===================== HERO ===================== */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;background:var(--rjava);text-align:center;}
.hero-img{position:absolute;inset:-7% 0 0 0;height:114%;background-size:cover;background-position:center;
  will-change:transform;transform:scale(1.08);animation:heroZoom 16s var(--ease) forwards;}
@keyframes heroZoom{to{transform:scale(1);}}
.hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,10,8,.5) 0%,rgba(26,15,10,.28) 38%,rgba(26,15,10,.5) 72%,rgba(20,10,8,.9) 100%);}
.hero-frame{position:absolute;inset:calc(var(--nav-h) + 12px) 20px 20px;border:1px solid rgba(201,168,76,.25);pointer-events:none;}
.hero-con{position:relative;z-index:2;padding:2rem 1.4rem;max-width:880px;}
.hero-eyebrow{display:inline-block;border:1px solid rgba(201,168,76,.55);color:var(--zlata-l);
  font-size:.66rem;letter-spacing:4px;text-transform:uppercase;padding:.5rem 1.4rem;margin-bottom:1.8rem;
  opacity:0;animation:up .9s ease forwards .2s;}
.hero-script{font-family:'Caveat',cursive;font-weight:700;color:var(--krem);
  font-size:clamp(4.6rem,15vw,9.6rem);line-height:.95;margin-top:clamp(.55rem,1.7vw,1.25rem);text-shadow:0 8px 46px rgba(0,0,0,.45);
  opacity:0;animation:up 1.1s var(--ease) forwards .5s;}
.hero-h1{font-family:'Cormorant Garamond',serif;color:rgba(245,237,224,.92);font-weight:500;
  font-size:clamp(.84rem,1.9vw,1.18rem);line-height:1.3;letter-spacing:3px;text-transform:uppercase;margin-bottom:.15rem;}
.hero-h1 .ln{display:block;opacity:0;transform:translateY(22px);animation:up 1s var(--ease) forwards;}
.hero-h1 .ln:nth-child(1){animation-delay:.35s;}
.hero-h1 .ln em{color:var(--zlata-l);font-style:italic;}
.hero-rule{width:0;height:1px;background:var(--zlata);margin:1.6rem auto;animation:rule 1s ease forwards .95s;}
@keyframes rule{to{width:72px;}}
.hero-sub{color:rgba(245,237,224,.8);font-size:clamp(.95rem,1.4vw,1.08rem);font-weight:300;
  max-width:30ch;margin:0 auto 2.4rem;line-height:1.85;opacity:0;animation:up .9s ease forwards 1.15s;}
.hero-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;opacity:0;animation:up .9s ease forwards 1.3s;}
@keyframes up{to{opacity:1;transform:none;}}
/* centered via left/right:0 (not translateX) — the `up` entrance animation
   ends on transform:none and would wipe a transform-based centering */
.hero-scroll{position:absolute;bottom:1.7rem;left:0;right:0;z-index:2;
  color:rgba(245,237,224,.5);font-size:.58rem;letter-spacing:3px;text-transform:uppercase;text-align:center;
  opacity:0;animation:up 1s ease forwards 1.8s;}
.hero-scroll .line{width:1px;height:42px;margin:.6rem auto 0;background:linear-gradient(180deg,var(--zlata),transparent);position:relative;overflow:hidden;}
.hero-scroll .line:after{content:'';position:absolute;top:-42px;left:0;width:1px;height:42px;background:var(--zlata-l);animation:drop 2.2s ease-in-out infinite;}
@keyframes drop{0%{top:-42px;}60%,100%{top:42px;}}

/* ===================== INTRO / ABOUT ===================== */
.intro{background:var(--krem-l);}
.intro-in{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center;}
.intro-fig{position:relative;overflow:hidden;}
.intro-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .9s var(--ease),filter .9s;}
.intro-fig:hover img{transform:scale(1.04);filter:saturate(1.05);}
.intro-fig .acc{position:absolute;bottom:-1.3rem;right:-1.3rem;width:130px;height:130px;border:2px solid var(--zlata);opacity:.45;z-index:-1;}
.intro-fig .badge{position:absolute;top:1.1rem;left:1.1rem;background:rgba(26,15,10,.68);backdrop-filter:blur(4px);
  color:var(--zlata-l);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;padding:.5rem .9rem;border:1px solid rgba(201,168,76,.4);}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2.6rem;}
.stat{border-left:2px solid var(--zlata);padding-left:1.1rem;}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:2.1rem;color:var(--bordo);font-weight:600;line-height:1;}
.stat .l{font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:.4rem;}

/* ===================== PILLARS ===================== */
.pillars{background:var(--krem);}
.pillars-hd{text-align:center;max-width:640px;margin:0 auto clamp(2.5rem,5vw,3.6rem);}
.pillars-hd .divider{margin:1.3rem auto;}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.pillar{position:relative;background:var(--krem-l);border:1px solid var(--krem-d);padding:3rem 2.2rem 2.6rem;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s,border-color .5s,background .5s;}
.pillar:before{content:'';position:absolute;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--zlata),var(--zlata-l));transition:width .6s var(--ease);}
.pillar:hover{transform:translateY(-8px);box-shadow:0 32px 64px -36px rgba(74,28,28,.38);border-color:transparent;background:#fff;}
.pillar:hover:before{width:100%;}
.pillar-no{position:absolute;top:1.3rem;right:1.7rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:2.7rem;color:var(--zlata);opacity:.3;line-height:1;pointer-events:none;transition:opacity .5s,color .5s;}
.pillar:hover .pillar-no{opacity:.6;color:var(--bordo);}
.pillar-ic{width:48px;height:48px;color:var(--bordo);margin-bottom:1.5rem;transition:color .5s,transform .5s var(--ease);}
.pillar-ic svg{width:100%;height:100%;display:block;}
.pillar:hover .pillar-ic{color:var(--zlata-d);transform:translateY(-3px);}
.pillar h3{font-family:'Cormorant Garamond',serif;font-size:1.32rem;color:var(--bordo);font-weight:500;margin-bottom:.7rem;}
.pillar p{font-size:.88rem;color:var(--soft);font-weight:300;line-height:1.85;}

/* ===================== RESTAURANT (facade sketch) ===================== */
.resto{background:var(--krem-l);}
.resto .divider{margin:1.35rem 0;}
.wine-txt .divider{margin:1.35rem 0;}
.resto-in{display:grid;grid-template-columns:1.7fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;}
.resto-fig{position:relative;overflow:hidden;}
.resto-svg{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .9s var(--ease),filter .9s;}
.resto-fig:hover .resto-svg{transform:scale(1.04);}
/* hand-drawn ink sketch variant: edges feather into the cream section, no frame */
.resto-fig.sketch{background:transparent;border:none;padding:0;overflow:visible;}
.resto-fig.sketch .resto-svg{aspect-ratio:1750/861;height:auto;object-fit:cover;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 7%,#000 93%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 8%,#000 92%,transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(to right,transparent 0,#000 7%,#000 93%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 8%,#000 92%,transparent 100%);
  mask-composite:intersect;}
.resto-fig.sketch:hover .resto-svg{transform:scale(1.02);}
@media(max-width:860px){.resto-in{grid-template-columns:1fr;}}

/* ===================== MENU ===================== */
.menu{background:var(--krem-l);}
.menu-head{text-align:center;max-width:640px;margin:0 auto;}
.menu-head .divider{margin:1.3rem auto;}
.tabs{display:flex;justify-content:center;gap:0;margin:2.4rem 0 2.4rem;border-bottom:1px solid rgba(74,28,28,.14);flex-wrap:wrap;}
.tab{padding:.9rem 1.9rem;font-size:.72rem;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;
  color:var(--muted);background:none;border:none;border-bottom:2px solid transparent;font-family:'EB Garamond',sans-serif;font-weight:600;transition:color .3s,border-color .3s;}
.tab:hover{color:var(--bordo);}
.tab.on{color:var(--bordo);border-bottom-color:var(--zlata);}
.menu-list{display:grid;grid-template-columns:1fr 1fr;gap:0 3rem;max-width:980px;margin:0 auto;}
.mitem{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:1.3rem 0;border-bottom:1px solid rgba(74,28,28,.1);animation:fade .5s ease both;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.mitem .name{font-family:'Cormorant Garamond',serif;font-size:1.02rem;color:var(--bordo);font-weight:500;}
.mitem .desc{font-size:.8rem;color:var(--muted);font-weight:300;margin-top:.25rem;}
.mitem .price{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--zlata-d);white-space:nowrap;font-weight:600;}
.menu-foot{text-align:center;margin-top:2.8rem;}

/* ===================== WINE (dark) ===================== */
.wine{background:linear-gradient(165deg,var(--bordo-d) 0%,var(--bordo) 55%,var(--bordo-d) 100%);position:relative;overflow:hidden;}
.wine:before{content:'';position:absolute;inset:0;opacity:.045;background-image:repeating-linear-gradient(45deg,var(--zlata) 0,var(--zlata) 1px,transparent 0,transparent 54px);}
.wine-in{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:center;}
.wine-fig{position:relative;overflow:hidden;border:1px solid rgba(201,168,76,.25);}
.wine-fig img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .9s var(--ease);}
.wine-fig:hover img{transform:scale(1.05);}
.wine-fig .cap{position:absolute;bottom:1rem;left:1rem;color:var(--zlata-l);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;background:rgba(26,15,10,.6);padding:.4rem .8rem;z-index:2;}
.wine-txt .h2{color:var(--krem);}
.wine-txt .h2 em{color:var(--zlata-l);}
.wine-txt .lead{color:rgba(245,237,224,.72);}
.wine-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2rem 0;}
.wcard{border:1px solid rgba(201,168,76,.22);padding:1.3rem;background:rgba(0,0,0,.12);transition:transform .4s var(--ease),border-color .4s,background .4s;}
.wcard:hover{transform:translateY(-6px);border-color:var(--zlata);background:rgba(201,168,76,.07);}
.wcard .t{font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--zlata);margin-bottom:.5rem;}
.wcard .nm{font-family:'Cormorant Garamond',serif;color:var(--krem);font-size:1rem;font-weight:500;margin-bottom:.3rem;}
.wcard .or{font-size:.76rem;color:rgba(245,237,224,.5);font-weight:300;}

/* ===================== GALLERY (editorial) ===================== */
.gallery{background:var(--krem);}
.gallery-hd{text-align:center;max-width:640px;margin:0 auto clamp(2rem,4vw,3rem);}
.gallery-hd .divider{margin:1.3rem auto;}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:var(--maxw);margin:0 auto;}
.gi{position:relative;overflow:hidden;aspect-ratio:4/5;cursor:pointer;}
.gi img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter .6s;filter:saturate(.96);}
.gi:hover img{transform:scale(1.06);filter:saturate(1.05);}
.gi:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,15,10,0) 42%,rgba(26,15,10,.86));opacity:.78;transition:opacity .45s;}
.gi:hover:after{opacity:.92;}
.gi .cap{position:absolute;left:1.3rem;right:1.3rem;bottom:1.2rem;z-index:2;color:var(--krem);font-family:'Cormorant Garamond',serif;font-size:1.08rem;transform:translateY(0);transition:transform .45s var(--ease);}
.gi:hover .cap{transform:translateY(-4px);}
.gi .cap small{display:block;font-family:'EB Garamond',sans-serif;font-size:.56rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--zlata-l);margin-bottom:.3rem;}
.gi .cap span::after{content:'→';margin-left:.5rem;display:inline-block;opacity:0;transform:translateX(-8px);transition:opacity .4s,transform .4s var(--ease);color:var(--zlata-l);}
.gi:hover .cap span::after{opacity:1;transform:none;}
.gallery-foot{text-align:center;margin-top:2.4rem;}

/* ===================== RESERVATION ===================== */
.reserve{background:var(--krem-l);}
.reserve-in{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2.5rem,6vw,4.5rem);align-items:start;max-width:1100px;margin:0 auto;}
.reserve-info .divider{margin:1.3rem 0;}
.reserve-info .lead{margin-bottom:2rem;}
.rinfo{display:flex;flex-direction:column;gap:1.3rem;}
.rinfo .row{display:flex;gap:1rem;align-items:flex-start;}
.rinfo .ic{width:42px;height:42px;flex-shrink:0;border:1px solid var(--zlata);display:flex;align-items:center;justify-content:center;color:var(--bordo);}
.rinfo .ic svg{width:18px;height:18px;}
.rinfo .lbl{font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem;}
.rinfo .val{font-size:.92rem;color:var(--tdark);line-height:1.5;}
.rinfo .val a{border-bottom:1px solid rgba(201,168,76,.4);}
/* handwritten sign-off under the info column (rezervacija.html only) */
.rinfo-sign{margin:3rem 0 0;}
.rinfo-sign .orn{display:block;color:var(--zlata);font-size:1.25rem;line-height:1;margin-bottom:.55rem;}
.rinfo-sign .script{font-family:'Caveat',cursive;font-weight:600;font-size:clamp(1.9rem,3.2vw,2.4rem);line-height:1.1;color:var(--bordo);transform:rotate(-2deg);transform-origin:left center;margin:0;}
.rcard{background:#fff;border:1px solid var(--krem-d);padding:clamp(1.6rem,4vw,2.6rem);box-shadow:0 30px 70px -40px rgba(74,28,28,.4);}
.rcard h3{font-family:'Cormorant Garamond',serif;color:var(--bordo);font-size:1.5rem;font-weight:600;margin-bottom:1.4rem;}
.rform{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.rf{display:flex;flex-direction:column;gap:.4rem;}
.rf.full{grid-column:1/-1;}
.rf label{font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}
.rf input,.rf select{background:var(--krem-l);border:1px solid rgba(74,28,28,.18);padding:.85rem .9rem;
  font-family:'EB Garamond',sans-serif;font-size:.92rem;color:var(--tdark);outline:none;transition:border-color .3s,box-shadow .3s;}
.rf input:focus,.rf select:focus{border-color:var(--zlata);box-shadow:0 0 0 3px rgba(201,168,76,.15);}
.rf.err input,.rf.err select{border-color:#a33;}
/* custom date picker */
.cm-dp{position:relative;}
.cm-dp-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  background:var(--krem-l);border:1px solid rgba(74,28,28,.18);padding:.85rem .9rem;cursor:pointer;
  font-family:'EB Garamond',sans-serif;font-size:.92rem;color:var(--tdark);outline:none;
  transition:border-color .3s,box-shadow .3s;text-align:left;}
.cm-dp-trigger:hover{border-color:var(--zlata);}
.cm-dp.open .cm-dp-trigger{border-color:var(--zlata);box-shadow:0 0 0 3px rgba(201,168,76,.15);}
.rf.err .cm-dp-trigger{border-color:#a33;}
.cm-dp-val{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cm-dp-val.ph{color:var(--muted);}
.cm-dp-ic{width:18px;height:18px;color:var(--zlata-d);flex-shrink:0;}
.cm-dp-pop{position:absolute;z-index:40;top:calc(100% + 8px);left:0;width:min(330px,92vw);
  background:#fff;border:1px solid var(--krem-d);border-top:3px solid var(--zlata);
  box-shadow:0 30px 70px -28px rgba(74,28,28,.5);padding:1rem 1rem 1.1rem;
  animation:cmDpIn .22s var(--ease) both;}
@keyframes cmDpIn{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}
.cm-dp-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem;}
.cm-dp-title{font-family:'Cormorant Garamond',serif;font-size:1.12rem;font-weight:600;color:var(--bordo);
  text-transform:capitalize;letter-spacing:.2px;}
.cm-dp-nav{width:32px;height:32px;border:1px solid rgba(74,28,28,.16);background:var(--krem-l);
  color:var(--bordo);font-size:1.2rem;line-height:1;cursor:pointer;border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .25s;}
.cm-dp-nav:hover{background:var(--bordo);color:var(--krem);border-color:var(--bordo);}
.cm-dp-wds{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;}
.cm-dp-wd{text-align:center;font-size:.66rem;letter-spacing:.5px;text-transform:uppercase;
  color:var(--muted);padding:.25rem 0;}
.cm-dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;}
.cm-dp-blank{aspect-ratio:1;}
.cm-dp-day{aspect-ratio:1;border:1px solid transparent;background:transparent;cursor:pointer;
  font-family:'EB Garamond',sans-serif;font-size:.86rem;color:var(--tdark);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .2s;}
.cm-dp-day:hover{background:var(--krem-d);color:var(--bordo);}
.cm-dp-day.today{border-color:var(--zlata);color:var(--bordo);font-weight:600;}
.cm-dp-day.sel{background:var(--bordo);color:var(--krem);border-color:var(--bordo);font-weight:600;}
.cm-dp-day.sel:hover{background:var(--bordo-d);}
.cm-dp-day.dis{color:rgba(74,28,28,.22);cursor:not-allowed;}
.cm-dp-day.dis:hover{background:transparent;color:rgba(74,28,28,.22);}
/* segmented choices: seating + time-slot chips (availability-ready) */
.seg{display:flex;gap:.5rem;flex-wrap:wrap;}
.slots{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;}
.slot{padding:.6rem .5rem;border:1px solid rgba(74,28,28,.2);background:var(--krem-l);font-size:.82rem;cursor:pointer;transition:all .25s;font-family:inherit;color:var(--soft);text-align:center;}
.seg .slot{flex:1;min-width:120px;}
.slot:hover{border-color:var(--zlata);color:var(--bordo);}
.slot.on{background:var(--bordo);color:var(--krem);border-color:var(--bordo);}
.slot.full{opacity:.35;text-decoration:line-through;cursor:not-allowed;}
.slot-hint{grid-column:1/-1;font-size:.7rem;color:var(--muted);font-weight:300;margin-top:.2rem;}
@media(max-width:480px){.slots{grid-template-columns:repeat(4,1fr);}}
.rnote{grid-column:1/-1;font-size:.74rem;color:#a33;min-height:1rem;}
.rsub{grid-column:1/-1;background:var(--bordo);color:var(--krem);border:none;padding:1.05rem;
  font-family:'EB Garamond',sans-serif;font-size:.72rem;letter-spacing:3px;text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .3s,transform .2s;}
.rsub:hover{background:var(--bordo-l);}
.rsub:active{transform:scale(.99);}
.rsub:disabled{opacity:.6;cursor:default;}
.rok{text-align:center;padding:1rem 0;animation:fade .6s ease both;}
.rok .ic{width:58px;height:58px;border-radius:50%;border:1.5px solid var(--zlata);color:var(--zlata);
  display:flex;align-items:center;justify-content:center;font-size:1.7rem;margin:0 auto 1.2rem;}
.rok h3{margin-bottom:.6rem;}
.rok p{font-size:.92rem;color:var(--soft);font-weight:300;line-height:1.7;}

/* ===================== HOURS (patterned) ===================== */
.hours{background-color:var(--krem);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cellipse cx='15' cy='15' rx='3' ry='8' fill='none' stroke='%234a1c1c' stroke-width='.7' opacity='.2'/%3E%3C/svg%3E");
  background-size:30px 30px;}
.hours-card{max-width:560px;margin:0 auto;background:var(--krem-l);border:1px solid rgba(74,28,28,.25);
  padding:clamp(2.6rem,5vw,3.6rem) clamp(1.5rem,4vw,2.6rem);text-align:center;box-shadow:0 34px 74px -46px rgba(74,28,28,.45);}
.hours-card .tag{display:block;margin-bottom:.8rem;}
.hours-card h2{font-family:'Cormorant Garamond',serif;color:var(--bordo);font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:5px;text-transform:uppercase;font-weight:600;}
.hours-card .sub{color:var(--zlata-d);font-size:.74rem;letter-spacing:1.5px;margin-top:.5rem;}
.hours-card .rows{display:flex;justify-content:center;gap:clamp(2rem,6vw,4rem);margin-top:2rem;flex-wrap:wrap;}
.hours-card .day{font-family:'Cormorant Garamond',serif;color:var(--bordo);font-weight:600;font-size:1.05rem;}
.hours-card .time{color:var(--soft);font-size:.95rem;margin-top:.3rem;}
.hours-card .note{margin-top:1.9rem;padding-top:1.5rem;border-top:1px solid rgba(74,28,28,.12);font-size:.82rem;color:var(--muted);font-weight:300;line-height:1.8;}
.hours-card .note a{color:var(--bordo);border-bottom:1px solid var(--zlata);}

/* ===================== LOCATION ===================== */
.location{background:var(--krem);}
.location-in{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
.location .divider{margin:1.3rem 0;}
.location-map{position:relative;display:block;text-decoration:none;background:var(--krem-l);
  border:1px solid rgba(201,168,76,.45);padding:.9rem .9rem .4rem;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s;}
.location-map:hover{transform:translateY(-4px);box-shadow:0 34px 64px -38px rgba(74,28,28,.42);}
.bled-wrap{position:relative;line-height:0;}
.bled-map{width:100%;height:auto;display:block;}
.bled-name{position:absolute;left:3.5%;top:3%;font-family:'Caveat',cursive;font-weight:700;
  font-size:clamp(1.4rem,3.2vw,2.3rem);color:var(--zlata-d);line-height:1;pointer-events:none;}
.bled-lab{position:absolute;transform:translate(-50%,-50%);font-family:'EB Garamond',serif;
  font-size:clamp(.6rem,1.25vw,.82rem);letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);pointer-events:none;white-space:nowrap;}
.bled-pin{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;pointer-events:none;}
.bled-pin svg{filter:drop-shadow(0 3px 4px rgba(74,28,28,.35));animation:pinDrop .6s var(--ease) both;transform-origin:center bottom;}
.bled-pin .lab{margin-top:2px;font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:clamp(.72rem,1.5vw,1rem);color:var(--bordo);background:rgba(247,241,230,.85);
  padding:0 .3rem;white-space:nowrap;}
.map-title{font-family:'Caveat',cursive;font-size:34px;font-weight:700;fill:var(--zlata-d);}
.map-label{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;fill:var(--bordo);}
.map-sub{font-family:'EB Garamond',sans-serif;font-size:10px;letter-spacing:1px;fill:var(--muted);}
.location-map .go{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:.5rem .2rem .4rem;
  color:var(--zlata-d);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;font-weight:600;transition:color .3s;}
.location-map:hover .go{color:var(--bordo);}
.map-pin{transform-origin:center bottom;animation:pinDrop .6s var(--ease) both;}
@keyframes pinDrop{0%{transform:translateY(-12px);opacity:0;}100%{transform:translateY(0);opacity:1;}}

/* ===================== LIGHTBOX ===================== */
.lb{position:fixed;inset:0;z-index:5000;background:rgba(20,10,8,.94);display:none;align-items:center;justify-content:center;padding:3vh 4vw;}
.lb.open{display:flex;}
.lb img{max-width:100%;max-height:92vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6);}
.lb-x,.lb-nav{position:absolute;background:none;border:1px solid rgba(201,168,76,.5);color:var(--zlata-l);cursor:pointer;transition:all .3s;}
.lb-x{top:2vh;right:4vw;width:44px;height:44px;font-size:1.3rem;}
.lb-nav{top:50%;transform:translateY(-50%);width:50px;height:64px;font-size:1.4rem;}
.lb-prev{left:2vw;}.lb-next{right:2vw;}
.lb-x:hover,.lb-nav:hover{background:var(--zlata);color:var(--rjava);}

/* ===================== HOMEPAGE RESPONSIVE ===================== */
@media(max-width:860px){
  .intro-in,.wine-in,.reserve-in,.location-in{grid-template-columns:1fr;gap:2.8rem;}
  .pillars-grid{grid-template-columns:1fr;}
  .intro-fig .acc{display:none;}
  .gal-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:560px){
  .menu-list{grid-template-columns:1fr;gap:0;}
  .wine-cards{grid-template-columns:1fr;}
  .rform{grid-template-columns:1fr;}
  .hero-frame{inset:78px 12px 12px;}
  .gal-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
}

/* reduced-motion: the hero text fades in via `animation: up ... forwards`, but the
   shared `*{animation:none}` rule cancels that fill — force the final visible state
   so the hero never renders blank for reduce-motion users. */
@media(prefers-reduced-motion:reduce){
  .hero-eyebrow,.hero-script,.hero-h1 .ln,.hero-sub,.hero-cta,.hero-scroll{opacity:1 !important;transform:none !important;}
  .hero-rule{width:72px !important;}
}
