/**
 * Zagorje Online – Main Stylesheet
 * @version 3.0.0
 */


:root{
--g1:#0e2318;--g2:#1a3d2b;--g3:#2d6a3f;--g4:#3a8a4a;--g5:#5cb85c;--g6:#7bc74d;--gp:#d4edda;
--gold:#c9a84c;--gold-l:#dfc06a;--gold-p:#f5ecd0;
--cream:#f8f6f0;--warm:#f0ebe0;--white:#fff;--char:#1e1e1c;--slate:#555550;--mist:#e4e0d8;
--wine:#6b2d35;--wine-d:#3a1520;
--ff:'Playfair Display',Georgia,serif;--fb:'DM Sans',system-ui,sans-serif;--fa:'Cormorant Garamond',Georgia,serif;
--ease:cubic-bezier(.25,.46,.45,.94);--snap:cubic-bezier(.34,1.56,.64,1);--pow:cubic-bezier(.77,0,.175,1);
--s1:0 2px 12px rgba(0,0,0,.06);--s2:0 8px 30px rgba(0,0,0,.1);--s3:0 16px 50px rgba(0,0,0,.15);--s4:0 24px 70px rgba(0,0,0,.2);--sg:0 8px 30px rgba(45,106,63,.2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:var(--fb);color:var(--char);background:var(--cream);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}ul{list-style:none}
::selection{background:var(--g3);color:var(--white)}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.025'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}

/* Animations */
.rv{opacity:0;transform:translateY(70px);transition:opacity 1s var(--ease),transform 1s var(--ease)}.rv.on{opacity:1;transform:translateY(0)}
.rv-l{opacity:0;transform:translateX(-90px);transition:opacity 1s var(--ease),transform 1s var(--ease)}.rv-l.on{opacity:1;transform:translateX(0)}
.rv-r{opacity:0;transform:translateX(90px);transition:opacity 1s var(--ease),transform 1s var(--ease)}.rv-r.on{opacity:1;transform:translateX(0)}
.rv-s{opacity:0;transform:scale(.88);transition:opacity 1s var(--ease),transform 1s var(--ease)}.rv-s.on{opacity:1;transform:scale(1)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}.d6{transition-delay:.6s}.d7{transition-delay:.7s}.d8{transition-delay:.8s}

/* Preloader */
.pre{position:fixed;inset:0;background:var(--g1);z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s,visibility .8s}.pre.done{opacity:0;visibility:hidden;pointer-events:none}
.pre img{height:60px;animation:beat 1.2s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1)}15%{transform:scale(1.15)}30%{transform:scale(1)}45%{transform:scale(1.08)}60%{transform:scale(1)}}
.pre-bar{width:180px;height:2px;background:rgba(255,255,255,.08);margin-top:2rem;border-radius:2px;overflow:hidden}.pre-fill{height:100%;background:linear-gradient(90deg,var(--g5),var(--g6));animation:load 2.2s var(--pow) forwards}
@keyframes load{0%{width:0}100%{width:100%}}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.1rem 3%;display:flex;align-items:center;justify-content:space-between;transition:all .5s var(--ease)}
.nav.sc{background:rgba(14,35,24,.96);backdrop-filter:blur(24px);padding:.65rem 3%;box-shadow:0 4px 30px rgba(0,0,0,.2)}
.nav-logo img{height:40px;transition:height .3s ease}.nav.sc .nav-logo img{height:32px}
.nl{display:flex;gap:.9rem;align-items:center}
.nl>a,.nm-p{color:rgba(255,255,255,.82);font-size:.72rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;position:relative;padding:.3rem 0;transition:color .3s;white-space:nowrap}
.nl>a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--g6);transition:width .4s var(--ease)}
.nl>a:hover,.nm-p:hover{color:var(--g6)}.nl>a:hover::after{width:100%}
.nm-p::after{display:none!important}
.nav-cta{background:var(--g3)!important;color:var(--white)!important;padding:.5rem 1.4rem!important;border-radius:50px;font-weight:600!important;border:1.5px solid var(--g5)!important;transition:all .3s!important}
.nav-cta:hover{background:var(--g5)!important;transform:translateY(-2px);box-shadow:var(--sg)}.nav-cta::after{display:none!important}
.nla{display:flex;gap:.3rem;margin-left:.6rem}.nla a{font-size:.68rem!important;opacity:.5;padding:.2rem .35rem!important;border-radius:3px}.nla a:hover,.nla a.on{opacity:1;background:rgba(255,255,255,.07)}.nla a::after{display:none!important}
/* ═══ MEGA MENU ═══ */
.nm{position:relative}
.nm-p{cursor:pointer;white-space:nowrap}
.nm-d{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);width:280px;background:rgba(14,35,24,.98);backdrop-filter:blur(24px);border-radius:14px;padding:.5rem;box-shadow:0 16px 50px rgba(0,0,0,.3);opacity:0;visibility:hidden;pointer-events:none;transition:all .25s var(--ease);z-index:1001;display:flex;flex-direction:column;gap:0}
.nm:hover .nm-d{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nm-d a.nm-i{display:flex!important;flex-direction:column!important;padding:.5rem .75rem!important;border-radius:8px;transition:background .2s;text-decoration:none!important;text-transform:none!important;letter-spacing:0!important;font-size:inherit!important;gap:0!important;position:relative}
.nm-d a.nm-i:hover{background:rgba(255,255,255,.07)}
.nm-d a.nm-i::after{display:none!important}
.nm-d a.nm-i .nm-l{display:block;color:#fff;font-size:.76rem;font-weight:600;letter-spacing:0!important;text-transform:none!important;line-height:1.3}
.nm-d a.nm-i .nm-desc{display:block;color:rgba(255,255,255,.35);font-size:.58rem;font-weight:400;letter-spacing:0!important;text-transform:none!important;margin-top:2px;line-height:1.3}
.nm-d::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);border:6px solid transparent;border-bottom-color:rgba(14,35,24,.98)}
@media(max-width:1100px){.nl{gap:.6rem}.nl>a,.nm-p{font-size:.68rem!important;letter-spacing:.03em!important}}
@media(max-width:1024px){.nm-d{position:static;transform:none!important;opacity:1;visibility:visible;pointer-events:auto;width:auto;background:rgba(255,255,255,.05);border-radius:8px;margin:.3rem 0;padding:.3rem;box-shadow:none}.nm-d::before{display:none}.nm-d a.nm-i .nm-desc{display:none}}

.nt{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001;padding:8px}
.nt span{width:26px;height:2px;background:var(--white);transition:all .3s;border-radius:2px}
.nt.on span:nth-child(1){transform:rotate(45deg) translateY(7px)}.nt.on span:nth-child(2){opacity:0}.nt.on span:nth-child(3){transform:rotate(-45deg) translateY(-7px)}
@media(max-width:1100px){.nt{display:flex}.nl{position:fixed;inset:0;background:var(--g1);flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;visibility:hidden;transition:all .5s}.nl.open{opacity:1;visibility:visible}.nl a{font-size:1.1rem}}

/* Hero */
.hero{position:relative;height:100vh;min-height:750px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.h-slider{position:absolute;inset:0;z-index:0}
.h-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.5s ease}.h-slide.act{opacity:1}
.h-slide img{width:100%;height:100%;object-fit:cover;animation:hz 25s ease-in-out infinite alternate}
@keyframes hz{0%{transform:scale(1)}100%{transform:scale(1.12)}}
.h-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,35,24,.35) 0%,rgba(14,35,24,.12) 30%,rgba(14,35,24,.3) 60%,rgba(14,35,24,.9) 100%);z-index:1}
.h-part{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.par{position:absolute;width:3px;height:3px;background:rgba(123,199,77,.35);border-radius:50%;animation:pf 8s linear infinite}
@keyframes pf{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-10vh) scale(1);opacity:0}}
.h-cnt{position:relative;z-index:2;text-align:center;max-width:960px;padding:0 2rem}
.h-badge{display:inline-flex;align-items:center;gap:.6rem;font-size:.7rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--g6);margin-bottom:1.8rem;animation:fu 1s .3s both;background:rgba(14,35,24,.5);backdrop-filter:blur(12px);padding:.45rem 1.4rem;border-radius:50px;border:1px solid rgba(123,199,77,.2)}
.h-ttl{font-family:var(--ff);font-size:clamp(3rem,7.5vw,6.5rem);font-weight:800;color:var(--white);line-height:1;margin-bottom:1.5rem;animation:fu 1s .5s both}
.h-ttl em{font-style:italic;color:var(--g6)}
.h-sub{font-family:var(--fa);font-size:clamp(1.1rem,2.2vw,1.5rem);color:rgba(255,255,255,.8);max-width:620px;margin:0 auto 2.5rem;line-height:1.65;animation:fu 1s .7s both;font-weight:300}
.h-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fu 1s .9s both}
@keyframes fu{from{opacity:0;transform:translateY(45px)}to{opacity:1;transform:translateY(0)}}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--fb);font-size:.86rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:.95rem 2.2rem;border-radius:50px;border:none;cursor:pointer;transition:all .4s var(--ease);position:relative;overflow:hidden}
.bg{background:var(--g3);color:var(--white);border:2px solid var(--g5)}
.bg:hover{background:var(--g5);transform:translateY(-3px);box-shadow:0 12px 35px rgba(45,106,63,.4)}
.bgh{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.25)}
.bgh:hover{border-color:var(--g6);color:var(--g6);transform:translateY(-3px)}
.bgold{background:var(--gold);color:var(--g1);border:2px solid var(--gold)}
.bgold:hover{background:var(--gold-l);transform:translateY(-3px);box-shadow:0 12px 35px rgba(201,168,76,.3)}

/* Hero slider nav */
.h-nav{position:absolute;bottom:5.5rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;align-items:center;gap:1rem;animation:fu 1s 1.3s both}
.h-dot{width:28px;height:3px;background:rgba(255,255,255,.25);border-radius:3px;cursor:pointer;transition:all .4s;border:none}.h-dot.act{width:44px;background:var(--g6)}
.h-arr{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:var(--white);font-size:.8rem}
.h-arr:hover{background:var(--g3);border-color:var(--g5)}
.h-scroll{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.3rem;color:rgba(255,255,255,.45);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;animation:fu 1s 1.5s both}
.h-scroll-ln{width:1px;height:35px;background:linear-gradient(to bottom,var(--g6),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.3;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}

/* Stats */
.stats-sec{background:var(--g2);padding:3.5rem 4%;position:relative;z-index:10}
.stats{display:grid;grid-template-columns:repeat(5,1fr);max-width:1200px;margin:0 auto}
.st{padding:1.8rem 1rem;text-align:center;position:relative;transition:background .4s}
.st:hover{background:rgba(255,255,255,.03)}
.st:not(:last-child)::after{content:'';position:absolute;right:0;top:20%;bottom:20%;width:1px;background:rgba(255,255,255,.07)}
.st-n{font-family:var(--ff);font-size:2.4rem;font-weight:800;color:var(--g6);line-height:1;margin-bottom:.3rem}
.st-l{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:500}
@media(max-width:900px){.stats{grid-template-columns:repeat(3,1fr)}.st{padding:1.4rem .8rem}.st-n{font-size:1.7rem}}
@media(max-width:550px){.stats{grid-template-columns:repeat(2,1fr)}}

/* Marquee */
.mq{background:var(--g1);padding:.85rem 0;overflow:hidden;border-top:1px solid rgba(123,199,77,.08)}
.mq-t{display:flex;animation:ms 45s linear infinite;width:max-content}
.mq-i{font-family:var(--fa);font-size:1.05rem;font-style:italic;color:rgba(123,199,77,.4);white-space:nowrap;padding:0 1.8rem;display:flex;align-items:center;gap:1.8rem}
.mq-s{width:4px;height:4px;background:var(--g5);border-radius:50%;opacity:.3;flex-shrink:0}
@keyframes ms{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Common */
.sec{padding:7rem 4%}.wrap{max-width:1320px;margin:0 auto}
.sd{background:var(--g1);color:var(--cream)}.sg{background:var(--g2);color:var(--cream)}.sc2{background:var(--cream)}.sw{background:var(--warm)}.swi{background:linear-gradient(135deg,var(--wine-d),var(--wine));color:var(--cream)}
.sh{text-align:center;margin-bottom:3.5rem}
.stag{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--g5);margin-bottom:.8rem}.stag i{font-size:.55rem}
.sttl{font-family:var(--ff);font-size:clamp(2.2rem,4.5vw,3.5rem);font-weight:700;line-height:1.12;margin-bottom:.8rem}
.sttl em{font-style:italic;color:var(--g3)}.sd .sttl em,.sg .sttl em{color:var(--g6)}.swi .sttl em{color:var(--gold)}
.sdsc{font-family:var(--fa);font-size:1.1rem;color:var(--slate);max-width:650px;margin:0 auto;line-height:1.7}
.sd .sdsc,.sg .sdsc,.swi .sdsc{color:rgba(248,246,240,.6)}

/* Slider with arrows */
.slider-wrap{position:relative}
.slider-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:0 0 1.5rem;-ms-overflow-style:none;scrollbar-width:none}
.slider-track::-webkit-scrollbar{display:none}
.slider-arr{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:var(--g2);border:2px solid var(--g5);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:all .3s;color:var(--white);font-size:1rem;box-shadow:var(--s3)}
.slider-arr:hover{background:var(--g5);transform:translateY(-50%) scale(1.08)}
.slider-arr.prev{left:-1rem}.slider-arr.next{right:-1rem}
@media(max-width:900px){.slider-arr.prev{left:.5rem}.slider-arr.next{right:.5rem}.slider-arr{width:40px;height:40px;font-size:.85rem}}

/* About */
.ab-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:5rem;align-items:center}
.ab-imgs{position:relative;height:560px}
.ab-i1{width:70%;height:420px;object-fit:cover;border-radius:18px;box-shadow:var(--s4);position:relative;z-index:2}
.ab-i2{position:absolute;bottom:0;right:0;width:50%;height:300px;object-fit:cover;border-radius:18px;border:6px solid var(--cream);box-shadow:var(--s3);z-index:3}
.ab-i3{position:absolute;top:2rem;right:1.5rem;width:130px;height:130px;object-fit:cover;border-radius:50%;border:5px solid var(--cream);box-shadow:var(--s2);z-index:4}
.ab-dec{position:absolute;bottom:4rem;left:-1.5rem;width:80px;height:80px;background:var(--g3);border-radius:16px;z-index:1;display:flex;align-items:center;justify-content:center;animation:fl 6s ease-in-out infinite}
.ab-dec i{color:var(--g6);font-size:1.8rem}
@keyframes fl{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.ab-text h3{font-family:var(--ff);font-size:2.5rem;font-weight:700;line-height:1.15;margin-bottom:1.3rem}.ab-text h3 em{color:var(--g3);font-style:italic}
.ab-text p{font-size:.98rem;color:var(--slate);margin-bottom:1.2rem;line-height:1.85}
.ab-feats{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:1.5rem}
.ab-ft{display:flex;align-items:flex-start;gap:.7rem;padding:1rem;background:var(--warm);border-radius:12px;transition:all .35s;border:1px solid transparent}
.ab-ft:hover{transform:translateY(-3px);box-shadow:var(--s2);border-color:var(--gp);background:var(--white)}
.ab-ft-ic{width:40px;height:40px;border-radius:10px;background:var(--g3);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ab-ft-ic i{color:var(--g6);font-size:.9rem}
.ab-ft strong{display:block;font-size:.85rem;margin-bottom:.1rem}.ab-ft span{font-size:.76rem;color:var(--slate)}
@media(max-width:960px){.ab-grid{grid-template-columns:1fr;gap:3rem}.ab-imgs{height:380px}}

/* Discover Cards */
.dg{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,300px);gap:1.1rem}
.dc{position:relative;border-radius:18px;overflow:hidden;cursor:pointer}.dc.tall{grid-row:span 2}
.dc img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}.dc:hover img{transform:scale(1.07)}
.dc-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(14,35,24,.88) 0%,rgba(14,35,24,.1) 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.8rem;transition:all .5s}
.dc:hover .dc-ov{background:linear-gradient(0deg,rgba(14,35,24,.95) 0%,rgba(14,35,24,.2) 45%)}
.dc-ic{width:48px;height:48px;border-radius:12px;background:rgba(123,199,77,.1);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;margin-bottom:.8rem;transition:all .4s;border:1px solid rgba(123,199,77,.15)}
.dc:hover .dc-ic{background:var(--g3);border-color:var(--g5)}.dc-ic i{color:var(--g6);font-size:1rem;transition:color .3s}.dc:hover .dc-ic i{color:var(--white)}
.dc h3{font-family:var(--ff);font-size:1.3rem;font-weight:700;color:var(--white);margin-bottom:.3rem}
.dc p{font-size:.82rem;color:rgba(255,255,255,.6);line-height:1.5;max-height:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .4s;opacity:0}
.dc:hover p{max-height:90px;opacity:1}
.dc-arr{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-6px,6px);transition:all .4s var(--ease)}
.dc:hover .dc-arr{opacity:1;transform:translate(0,0)}.dc-arr i{color:var(--white);font-size:.8rem}
@media(max-width:900px){.dg{grid-template-columns:1fr 1fr;grid-template-rows:auto}.dc{min-height:260px}.dc.tall{grid-row:span 1}}
@media(max-width:600px){.dg{grid-template-columns:1fr}}

/* Castle */
.cs{display:grid;grid-template-columns:1.15fr 1fr;gap:4rem;align-items:center}
.cs-mos{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.cs-tile{border-radius:14px;overflow:hidden;position:relative}.cs-tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.cs-tile:hover img{transform:scale(1.05)}
.cs-tile:first-child{grid-row:span 2;min-height:420px}.cs-tile:not(:first-child){min-height:200px}
.cs-lbl{position:absolute;bottom:.7rem;left:.7rem;background:rgba(14,35,24,.88);backdrop-filter:blur(10px);color:var(--white);padding:.35rem .9rem;border-radius:7px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.35rem}.cs-lbl i{color:var(--g6);font-size:.6rem}
.cs-info h3{font-family:var(--ff);font-size:2.4rem;font-weight:700;line-height:1.15;margin-bottom:1rem;color:var(--cream)}.cs-info h3 em{color:var(--g6);font-style:italic}
.cs-info>p{font-size:.95rem;color:rgba(248,246,240,.65);margin-bottom:1.2rem;line-height:1.85}
.cs-li{display:flex;align-items:flex-start;gap:.8rem;padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.05);transition:all .3s}.cs-li:hover{padding-left:.4rem}
.cs-li-d{width:30px;height:30px;border-radius:8px;background:rgba(123,199,77,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}.cs-li-d i{color:var(--g6);font-size:.7rem}
.cs-li strong{color:var(--cream);font-size:.88rem}.cs-li span{font-size:.84rem;color:rgba(248,246,240,.55)}
@media(max-width:960px){.cs{grid-template-columns:1fr}.cs-tile:first-child{min-height:280px}}

/* Gastro bento */
.gb{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:270px 270px;gap:1rem}
.gi{position:relative;border-radius:18px;overflow:hidden;cursor:pointer}.gi.big{grid-column:span 2;grid-row:span 2}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.gi:hover img{transform:scale(1.06)}
.gi-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.72) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;transition:all .4s}
.gi:hover .gi-ov{background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 50%)}
.gi-chip{display:inline-block;background:rgba(123,199,77,.12);color:var(--g6);padding:.18rem .7rem;border-radius:50px;font-size:.65rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.4rem;backdrop-filter:blur(8px);border:1px solid rgba(123,199,77,.15);width:fit-content}
.gi h4{font-family:var(--ff);font-size:1.15rem;font-weight:700;color:var(--white);margin-bottom:.2rem}.gi.big h4{font-size:1.6rem}
.gi p{font-size:.8rem;color:rgba(255,255,255,.65);line-height:1.5}
@media(max-width:900px){.gb{grid-template-columns:1fr 1fr;grid-template-rows:auto}.gi{min-height:240px}.gi.big{grid-column:span 2;grid-row:span 1}}
@media(max-width:600px){.gb{grid-template-columns:1fr}.gi.big{grid-column:span 1}}

/* Wine */
.wg{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative}
.wg-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 15% 50%,rgba(107,45,53,.3) 0%,transparent 50%),radial-gradient(ellipse at 85% 50%,rgba(201,168,76,.08) 0%,transparent 50%)}
.wt h3{font-family:var(--ff);font-size:2.5rem;font-weight:700;line-height:1.15;margin-bottom:1.2rem;color:var(--cream)}.wt h3 em{color:var(--gold);font-style:italic}
.wt p{color:rgba(248,246,240,.65);margin-bottom:1.1rem;line-height:1.85;font-size:.95rem}
.ws{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.wch{padding:.45rem 1.1rem;border:1px solid rgba(201,168,76,.2);border-radius:50px;font-size:.78rem;color:var(--gold-l);transition:all .3s;cursor:pointer}.wch:hover{background:var(--gold);color:var(--wine-d);border-color:var(--gold)}
.wiw{position:relative;border-radius:20px;overflow:hidden;height:500px}
.wiw img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}.wiw:hover img{transform:scale(1.04)}
.wb{position:absolute;bottom:1.2rem;left:1.2rem;background:rgba(58,21,32,.9);backdrop-filter:blur(15px);padding:1rem 1.4rem;border-radius:14px;border:1px solid rgba(201,168,76,.12)}
.wb .n{font-family:var(--ff);font-size:1.8rem;font-weight:700;color:var(--gold);line-height:1}.wb .l{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(248,246,240,.45);margin-top:.2rem}
@media(max-width:960px){.wg{grid-template-columns:1fr;gap:3rem}.wiw{height:350px}}

/* Accommodation cards */
.ac{min-width:360px;scroll-snap-align:start;background:var(--white);border-radius:18px;overflow:hidden;transition:all .4s var(--ease);flex-shrink:0;border:1px solid var(--mist)}
.ac:hover{transform:translateY(-6px);box-shadow:var(--s4);border-color:var(--gp)}
.ac-img{position:relative;height:240px;overflow:hidden}.ac-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}.ac:hover .ac-img img{transform:scale(1.05)}
.ac-bdg{position:absolute;top:.8rem;left:.8rem;background:var(--g3);color:var(--white);padding:.2rem .8rem;border-radius:50px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.ac-rt{position:absolute;top:.8rem;right:.8rem;background:rgba(14,35,24,.7);backdrop-filter:blur(10px);color:var(--white);padding:.2rem .6rem;border-radius:50px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.ac-rt i{color:var(--gold);font-size:.6rem}
.ac-bd{padding:1.3rem}
.ac-bd h4{font-family:var(--ff);font-size:1.15rem;font-weight:700;margin-bottom:.35rem}
.ac-loc{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--slate);margin-bottom:.8rem}.ac-loc i{color:var(--g3);font-size:.65rem}
.ac-ams{display:flex;gap:.9rem;padding-top:.8rem;border-top:1px solid var(--mist)}.ac-am{display:flex;align-items:center;gap:.3rem;font-size:.73rem;color:var(--slate)}.ac-am i{color:var(--g4);font-size:.78rem}
.ac-pr{display:flex;align-items:baseline;gap:.25rem;margin-top:.8rem}.ac-pr .f{font-size:.7rem;color:var(--slate)}.ac-pr .a{font-family:var(--ff);font-size:1.3rem;font-weight:700;color:var(--g2)}.ac-pr .p{font-size:.73rem;color:var(--slate)}
@media(max-width:600px){.ac{min-width:290px}}

/* Thermal */
.th-hero{position:relative;border-radius:24px;overflow:hidden;min-height:500px;display:flex;align-items:center}
.th-bg{position:absolute;inset:0}.th-bg img{width:100%;height:100%;object-fit:cover}
.th-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,35,24,.94) 0%,rgba(14,35,24,.6) 50%,transparent 100%)}
.th-cnt{position:relative;z-index:2;padding:3.5rem;max-width:540px}
.th-cnt h3{font-family:var(--ff);font-size:2.4rem;font-weight:700;color:var(--white);margin-bottom:.8rem;line-height:1.15}.th-cnt h3 em{color:var(--g6);font-style:italic}
.th-cnt p{color:rgba(255,255,255,.75);margin-bottom:1.8rem;line-height:1.8}
.th-g{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.th-p{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.05);backdrop-filter:blur(10px);padding:.75rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.05);transition:all .3s}
.th-p:hover{background:rgba(123,199,77,.08);border-color:rgba(123,199,77,.15)}
.th-p i{color:var(--g6);font-size:1rem;flex-shrink:0}.th-p span{font-size:.82rem;color:var(--cream);font-weight:500}
@media(max-width:768px){.th-cnt{padding:2rem}.th-g{grid-template-columns:1fr}}

/* EXPANDED Outdoor */
.out-hero{position:relative;border-radius:24px;overflow:hidden;min-height:400px;display:flex;align-items:center;margin-bottom:3rem}
.out-hero-bg{position:absolute;inset:0}.out-hero-bg img{width:100%;height:100%;object-fit:cover}
.out-hero-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,35,24,.92) 0%,rgba(14,35,24,.5) 50%,transparent 100%)}
.out-hero-cnt{position:relative;z-index:2;padding:3.5rem;max-width:560px}
.out-hero-cnt h3{font-family:var(--ff);font-size:2.4rem;font-weight:700;color:var(--white);margin-bottom:.8rem;line-height:1.15}.out-hero-cnt h3 em{color:var(--g6);font-style:italic}
.out-hero-cnt p{color:rgba(255,255,255,.75);margin-bottom:1.5rem;line-height:1.8}

.og{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:2.5rem}
.oc{position:relative;border-radius:18px;overflow:hidden;min-height:320px;display:flex;align-items:flex-end;cursor:pointer}
.oc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.oc:hover img{transform:scale(1.07)}
.oc-bd{position:relative;z-index:2;padding:1.8rem;width:100%;background:linear-gradient(0deg,rgba(0,0,0,.75) 0%,transparent 100%)}
.oc h4{font-family:var(--ff);font-size:1.3rem;font-weight:700;color:var(--white);margin-bottom:.3rem}.oc p{font-size:.82rem;color:rgba(255,255,255,.65)}
.oc-ic{position:absolute;top:1rem;right:1rem;width:44px;height:44px;background:rgba(14,35,24,.45);backdrop-filter:blur(8px);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:2;transition:all .3s;border:1px solid rgba(123,199,77,.12)}
.oc:hover .oc-ic{background:var(--g3);border-color:var(--g5)}.oc-ic i{color:var(--g6);font-size:1rem;transition:color .3s}.oc:hover .oc-ic i{color:var(--white)}

/* Additional outdoor cards */
.out-extras{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.oe{background:var(--white);border-radius:16px;padding:1.8rem;text-align:center;transition:all .4s;border:1px solid var(--mist)}
.oe:hover{transform:translateY(-5px);box-shadow:var(--s3);border-color:var(--gp)}
.oe-ic{width:56px;height:56px;border-radius:14px;background:var(--gp);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;transition:all .4s}
.oe:hover .oe-ic{background:var(--g3)}.oe-ic i{color:var(--g3);font-size:1.3rem;transition:color .3s}.oe:hover .oe-ic i{color:var(--white)}
.oe h4{font-family:var(--ff);font-size:1rem;font-weight:700;margin-bottom:.3rem}.oe p{font-size:.8rem;color:var(--slate);line-height:1.5}
@media(max-width:900px){.og{grid-template-columns:1fr 1fr}.out-extras{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.og{grid-template-columns:1fr}.out-extras{grid-template-columns:1fr}}

/* EXPANDED Traditions */
.tr-showcase{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-bottom:4rem}
.tr-img{position:relative;border-radius:20px;overflow:hidden;height:480px}
.tr-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}.tr-img:hover img{transform:scale(1.04)}
.tr-text h3{font-family:var(--ff);font-size:2.4rem;font-weight:700;line-height:1.15;margin-bottom:1.2rem;color:var(--cream)}.tr-text h3 em{color:var(--g6);font-style:italic}
.tr-text p{color:rgba(248,246,240,.65);margin-bottom:1.2rem;line-height:1.85;font-size:.95rem}
.tr-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.trc{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:18px;padding:2rem;text-align:center;transition:all .4s;position:relative;overflow:hidden}
.trc:hover{transform:translateY(-5px);border-color:rgba(123,199,77,.12);background:rgba(255,255,255,.05)}
.trc-ic{width:58px;height:58px;border-radius:16px;background:rgba(123,199,77,.06);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;transition:all .4s}
.trc:hover .trc-ic{background:var(--g3)}.trc-ic i{color:var(--g6);font-size:1.3rem;transition:color .3s}.trc:hover .trc-ic i{color:var(--white)}
.trc h4{font-family:var(--ff);font-size:1.05rem;font-weight:700;color:var(--cream);margin-bottom:.4rem}.trc p{font-size:.82rem;color:rgba(248,246,240,.5);line-height:1.55}
@media(max-width:960px){.tr-showcase{grid-template-columns:1fr;gap:2rem}.tr-img{height:320px}}
@media(max-width:900px){.tr-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.tr-grid{grid-template-columns:1fr}}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:220px 220px;gap:.6rem}
.gal-item{border-radius:12px;overflow:hidden;position:relative;cursor:pointer}
.gal-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s}
.gal-item:hover img{transform:scale(1.06);filter:brightness(1.1)}
.gal-item::after{content:'';position:absolute;inset:0;background:rgba(14,35,24,0);transition:background .4s}.gal-item:hover::after{background:rgba(14,35,24,.15)}
.gal-zoom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2;transition:transform .4s var(--snap);color:var(--white);font-size:1rem}
.gal-item:hover .gal-zoom{transform:translate(-50%,-50%) scale(1)}
@media(max-width:768px){.gal{grid-template-columns:1fr 1fr;grid-template-rows:auto}.gal-item{min-height:180px}.gal-item:nth-child(1){grid-column:span 2;grid-row:span 1}}

/* Events */
.ev-tl{position:relative;padding-left:2.5rem}.ev-tl::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--g6),var(--g3),var(--gold),var(--wine))}
.ev{position:relative;padding:1.2rem 0 2.5rem 2.2rem}
.ev-dot{position:absolute;left:-2.95rem;top:1.5rem;width:12px;height:12px;border-radius:50%;background:var(--g6);border:3px solid var(--warm);box-shadow:0 0 0 4px rgba(123,199,77,.12)}
.ev-ssn{font-size:.65rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--g3);margin-bottom:.5rem}
.ev-card{background:var(--white);border-radius:14px;padding:1.5rem;display:grid;grid-template-columns:auto 1fr;gap:1.2rem;box-shadow:var(--s1);transition:all .35s;border:1px solid var(--mist)}
.ev-card:hover{transform:translateX(4px);box-shadow:var(--s2);border-color:var(--gp)}
.ev-dt{background:var(--g2);color:var(--white);border-radius:10px;padding:.7rem .9rem;text-align:center;min-width:65px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ev-dt .m{font-size:.55rem;text-transform:uppercase;letter-spacing:.15em;color:var(--g6);font-weight:600}
.ev-dt .d{font-family:var(--ff);font-size:1.6rem;font-weight:700;line-height:1;margin:.15rem 0}
.ev-det h4{font-family:var(--ff);font-size:1.1rem;font-weight:700;margin-bottom:.3rem}.ev-det p{font-size:.85rem;color:var(--slate);line-height:1.55}
.ev-loc{display:inline-flex;align-items:center;gap:.35rem;font-size:.73rem;color:var(--g3);margin-top:.4rem}

/* Testimonials */
.tsg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.tc{background:var(--white);border:1px solid var(--mist);border-radius:18px;padding:2.2rem;transition:all .4s;position:relative}
.tc:hover{transform:translateY(-4px);box-shadow:var(--s3);border-color:var(--gp)}
.tc-stars{display:flex;gap:.15rem;margin-bottom:1rem}.tc-stars i{color:var(--gold);font-size:.75rem}
.tc blockquote{font-family:var(--fa);font-size:1.05rem;font-style:italic;color:var(--slate);line-height:1.65;margin-bottom:1.5rem}
.tc-aut{display:flex;align-items:center;gap:.7rem}
.tc-av{width:40px;height:40px;border-radius:50%;background:var(--g3);display:flex;align-items:center;justify-content:center;font-family:var(--ff);font-size:.95rem;font-weight:700;color:var(--white)}
.tc-aut strong{display:block;font-size:.85rem}.tc-aut span{font-size:.73rem;color:var(--slate)}
.tc-qm{position:absolute;top:1rem;right:1.2rem;font-family:var(--ff);font-size:3.5rem;color:var(--gp);line-height:1}
@media(max-width:768px){.tsg{grid-template-columns:1fr}}

/* Park CTA */
.pk-cta{position:relative;border-radius:24px;overflow:hidden;min-height:460px;display:flex;align-items:center;justify-content:center;text-align:center}
.pk-bg{position:absolute;inset:0}.pk-bg img{width:100%;height:100%;object-fit:cover}
.pk-ov{position:absolute;inset:0;background:rgba(14,35,24,.58)}
.pk-in{position:relative;z-index:2;max-width:700px;padding:3rem 2rem}
.pk-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--g3);color:var(--white);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.4rem 1.1rem;border-radius:50px;margin-bottom:1.3rem;border:1.5px solid var(--g5);animation:bp 3s ease infinite}
@keyframes bp{0%,100%{box-shadow:0 0 0 0 rgba(123,199,77,.3)}50%{box-shadow:0 0 0 10px rgba(123,199,77,0)}}
.pk-in h3{font-family:var(--ff);font-size:clamp(2rem,4vw,2.8rem);font-weight:700;color:var(--white);margin-bottom:.8rem;line-height:1.15}.pk-in h3 em{color:var(--g6);font-style:italic}
.pk-in p{color:rgba(255,255,255,.78);font-size:1rem;margin-bottom:1.5rem;line-height:1.7}
.pk-stats{display:flex;gap:1.8rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}
.pk-st{text-align:center}.pk-st .n{font-family:var(--ff);font-size:1.6rem;font-weight:700;color:var(--g6);line-height:1}.pk-st .l{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.45);margin-top:.2rem}

/* Newsletter */
.nws{background:var(--g2);border-radius:24px;padding:3.5rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;position:relative;overflow:hidden}
.nws::before{content:'';position:absolute;top:-60%;right:-15%;width:450px;height:450px;background:radial-gradient(circle,rgba(123,199,77,.08) 0%,transparent 70%);pointer-events:none}
.nws h3{font-family:var(--ff);font-size:2rem;font-weight:700;color:var(--white);margin-bottom:.6rem;line-height:1.2}.nws h3 em{color:var(--g6);font-style:italic}
.nws>div>p{color:rgba(255,255,255,.55);font-size:.88rem}
.nws-f{display:flex;gap:.6rem}.nws-f input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:50px;padding:.9rem 1.3rem;color:var(--white);font-family:var(--fb);font-size:.85rem;outline:none;transition:border-color .3s}.nws-f input::placeholder{color:rgba(255,255,255,.3)}.nws-f input:focus{border-color:var(--g5)}
.nws-f button{background:var(--g3);border:1.5px solid var(--g5);border-radius:50px;padding:.9rem 1.5rem;font-family:var(--fb);font-size:.82rem;font-weight:600;color:var(--white);cursor:pointer;transition:all .3s;white-space:nowrap}
.nws-f button:hover{background:var(--g5);transform:translateY(-2px);box-shadow:var(--sg)}
@media(max-width:768px){.nws{grid-template-columns:1fr;padding:2.2rem}.nws-f{flex-direction:column}}

/* Footer */
.ftr{background:var(--g1);color:var(--cream);padding:4.5rem 4% 1.5rem}
.fg{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.05)}
.fb img{height:38px;margin-bottom:1rem}.fb p{font-size:.85rem;color:rgba(248,246,240,.45);line-height:1.7;max-width:360px}
.fs{display:flex;gap:.5rem;margin-top:1.2rem}
.fs a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;transition:all .3s}.fs a:hover{background:var(--g3);border-color:var(--g5)}
.fs a i{color:rgba(248,246,240,.5);font-size:.8rem;transition:color .3s}.fs a:hover i{color:var(--white)}
.fc h5{font-family:var(--ff);font-size:.9rem;font-weight:700;margin-bottom:1.1rem;color:var(--g6)}
.fc a{display:block;font-size:.82rem;color:rgba(248,246,240,.45);padding:.3rem 0;transition:all .3s}.fc a:hover{color:var(--g6);padding-left:.2rem}
.fbtm{padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem}
.fbtm p{font-size:.75rem;color:rgba(248,246,240,.25)}.fbtm a{color:var(--g5)}
@media(max-width:768px){.fg{grid-template-columns:1fr 1fr}}@media(max-width:500px){.fg{grid-template-columns:1fr}}

/* Back to top */
.btt{position:fixed;bottom:2rem;right:2rem;width:46px;height:46px;background:var(--g3);color:var(--white);border:1.5px solid var(--g5);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .4s var(--ease);z-index:999;box-shadow:var(--sg);font-size:.85rem}.btt.vis{opacity:1;visibility:visible;transform:translateY(0)}.btt:hover{background:var(--g5);transform:translateY(-3px)}
