/* ============================================================
   Climate Dialogues — Shared Theme Stylesheet
   Maintains original Sora/DM Sans typography & canopy/ember palette
   ============================================================ */
:root{
  --canopy:#1A3D2C;--canopy-deep:#0F2419;--canopy-mid:#2A5C40;
  --ocean:#2B6E98;--ocean-light:#3D82AD;
  --ember:#C96A28;--ember-light:#D97F3A;
  --celadon:#6EA882;--cloud:#E6EAE3;--cloud-dark:#D8DDD4;
  --off-white:#F4F5F1;--wh:#ffffff;
  --ch:#1A3D2C;--mid:#5A6E62;--lt:#8A9A8A;
  --teal:var(--canopy);--td:var(--canopy-deep);--tl:var(--canopy-mid);
  --tp:var(--cloud);--am:var(--ember);--al:var(--ember-light);
  --cr:var(--off-white);--cd:var(--cloud-dark);
  --se:'Sora','DM Sans',sans-serif;--ds:'Sora',sans-serif;--sa:'DM Sans',sans-serif;
  --ra:4px;--sh:0 8px 40px rgba(15,36,25,.10);--sl:0 24px 80px rgba(15,36,25,.15)
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--off-white);color:var(--canopy);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;font-family:var(--sa)}
input,textarea,select{font-family:var(--sa)}
img{max-width:100%;display:block}
.icon{width:1em;height:1em;display:inline-block;vertical-align:-0.125em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:999;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;height:70px;background:rgba(15,36,25,.97);backdrop-filter:blur(12px);border-bottom:1px solid rgba(110,168,130,.12)}
.nl-main{font-family:var(--ds);font-size:1.15rem;font-weight:700;color:#F4F5F1;letter-spacing:-.015em;line-height:1.05}
.nl-sub{font-size:.6rem;font-weight:300;letter-spacing:.28em;text-transform:uppercase;color:var(--celadon);opacity:.85;line-height:1;margin-bottom:2px}
.nlinks{display:flex;align-items:center;gap:2rem}
.nlinks a{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);transition:color .2s}
.nlinks a:hover,.nlinks a.cur{color:var(--al)}
.ncta{background:var(--ember);color:var(--wh)!important;padding:.48rem 1.2rem;border-radius:var(--ra);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;transition:all .2s}
.ncta:hover{background:var(--al)!important;transform:translateY(-1px)}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hbg span{width:22px;height:2px;background:var(--wh);border-radius:2px;display:block}
.mob-menu{display:none;position:fixed;top:70px;left:0;right:0;bottom:0;background:var(--td);z-index:998;flex-direction:column;padding:2rem;gap:1.2rem;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-menu a{font-size:1.1rem;font-family:var(--se);color:rgba(255,255,255,.85);padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.07)}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;background:linear-gradient(140deg,var(--canopy-deep) 0%,var(--canopy) 50%,var(--canopy-mid) 100%);position:relative;overflow:hidden;padding-top:70px}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.04) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(201,129,58,.08) 0%,transparent 40%)}
.hcont{position:relative;z-index:1;display:grid;gap:2.5rem;align-items:center;max-width:1160px;margin:0 auto;padding:5rem 5vw 4rem}
.hey{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--al);margin-bottom:1.1rem;display:flex;align-items:center;gap:.6rem;justify-content:center}
.hey::before{content:'';width:24px;height:1px;background:var(--al)}
.hero h1{font-family:var(--ds);font-size:clamp(2.2rem,8vw,3.9rem);color:var(--wh);line-height:1.09;margin-bottom:1.3rem;font-weight:400;text-align:center}
.hero h1 em{font-style:italic;color:var(--al)}
.hsub{font-size:1rem;color:rgba(255,255,255,.72);line-height:1.8;margin-bottom:2rem;max-width:100%;text-align:center}
.hbtns{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}
.bp{background:var(--am);color:var(--wh);padding:.8rem 1.8rem;border-radius:var(--ra);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}
.bp:hover{background:var(--al);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,129,58,.28)}
.bo{border:1.5px solid rgba(255,255,255,.38);color:var(--wh);padding:.8rem 1.8rem;border-radius:var(--ra);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:all .2s;background:transparent;display:inline-flex;align-items:center;gap:.5rem}
.bo:hover{border-color:var(--wh);background:rgba(255,255,255,.07);transform:translateY(-2px)}

/* HERO MEDIA / CAROUSEL */
.hero-media{width:100%;max-width:460px;aspect-ratio:4/5;border-radius:6px;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.13);box-shadow:var(--sl);margin:0 auto}
.hero-media .hslide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;background:linear-gradient(145deg,rgba(255,255,255,.11),rgba(255,255,255,.04))}
.hero-media .hslide.active{opacity:1}
.hero-media .hslide img{width:100%;height:100%;object-fit:cover;display:block}
.hero-media .hbadge{position:absolute;bottom:1.2rem;left:1.2rem;right:1.2rem;background:rgba(15,36,25,.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);padding:.9rem 1.1rem;border-radius:var(--ra);z-index:5}
.hbn{font-family:var(--se);font-size:1.05rem;color:var(--wh);font-weight:500}
.hbt{font-size:.68rem;color:rgba(255,255,255,.6);letter-spacing:.1em;text-transform:uppercase;margin-top:.15rem}
.hero-dots{position:absolute;bottom:1.2rem;right:1.2rem;display:flex;gap:.35rem;z-index:6}
.hero-dots span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.35);transition:background .2s}
.hero-dots span.active{background:var(--am)}

/* STATS */
.sstrip{background:var(--canopy-deep);padding:1.2rem 5vw;display:grid;grid-template-columns:1fr 1fr;gap:.8rem;border-top:1px solid rgba(110,168,130,.12)}
@media(min-width:600px){.sstrip{grid-template-columns:repeat(4,1fr);gap:0}}
.stn{font-family:var(--ds);font-size:1.7rem;color:var(--ember);font-weight:700}
.stl{font-size:.68rem;color:rgba(255,255,255,.5);letter-spacing:.18em;text-transform:uppercase;margin-top:.15rem}

/* SECTIONS */
.sec{padding:5.5rem 5vw}
.si{max-width:1160px;margin:0 auto}
.ey{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--am);margin-bottom:.9rem;display:flex;align-items:center;gap:.55rem}
.ey::before{content:'';width:18px;height:1px;background:var(--am)}
.st{font-family:var(--ds);font-size:clamp(1.9rem,3.8vw,2.9rem);color:var(--td);line-height:1.14;margin-bottom:1.1rem;font-weight:400}
.st em{font-style:italic;color:var(--am)}
.sl{font-size:1rem;color:var(--mid);line-height:1.78;max-width:580px}
.div{width:44px;height:2px;background:var(--am);margin:1.4rem 0}

/* ABOUT */
.agrid{display:grid;grid-template-columns:1fr;gap:2.5rem}
.aphoto{aspect-ratio:4/5;background:linear-gradient(145deg,var(--tp),var(--cd));border-radius:6px;position:relative;overflow:hidden;border:1px solid rgba(26,92,88,.09)}
.aphoto img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.apacc{position:absolute;bottom:1.4rem;left:1.4rem;right:1.4rem;background:var(--td);padding:1.1rem 1.3rem;border-radius:var(--ra);z-index:3}
.apacc p{font-size:.88rem;color:rgba(255,255,255,.68);line-height:1.65;font-style:italic;font-family:var(--se)}
.clist{display:flex;flex-direction:column;gap:.75rem;margin-top:1.4rem}
.cred{display:flex;align-items:center;gap:.9rem;padding:.85rem 1rem;background:var(--cloud);border-radius:var(--ra);border-left:3px solid var(--ocean)}
.cicon{width:34px;height:34px;background:var(--ocean);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--wh)}
.cicon .icon{width:16px;height:16px}
.ctxt{font-size:.83rem;color:var(--td);font-weight:500}
.csub{font-size:.72rem;color:var(--mid);margin-top:.1rem}

/* SERVICES */
.sbg{background:var(--td)}
.sbg .st{color:var(--wh)}.sbg .sl{color:rgba(255,255,255,.62)}.sbg .ey{color:var(--al)}.sbg .ey::before{background:var(--al)}
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:1.4rem;margin-top:2.8rem}
.scard{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);border-radius:var(--ra);overflow:hidden;transition:all .25s;position:relative;display:flex;flex-direction:column}
.scard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--am);transform:scaleX(0);transform-origin:left;transition:transform .3s;z-index:2}
.scard:hover{background:rgba(255,255,255,.09);transform:translateY(-4px);box-shadow:var(--sh)}.scard:hover::before{transform:scaleX(1)}
.scard-img{width:100%;height:160px;object-fit:cover;background:linear-gradient(135deg,var(--tp),var(--cd))}
.scard-body{padding:1.8rem;display:flex;flex-direction:column;flex:1}
.sico{width:1.7rem;height:1.7rem;margin-bottom:1.1rem;color:var(--al)}
.sico .icon{width:100%;height:100%}
.stag{font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;color:var(--al);margin-bottom:.55rem}
.stitl{font-family:var(--se);font-size:1.25rem;color:var(--wh);margin-bottom:.65rem;font-weight:500}
.sdesc{font-size:.85rem;color:rgba(255,255,255,.58);line-height:1.75;margin-bottom:1.4rem;flex:1}
.sprc{font-family:var(--se);font-size:1rem;color:var(--al);margin-bottom:1.1rem}
.bsv{background:transparent;border:1px solid rgba(255,255,255,.22);color:var(--wh);padding:.55rem 1.2rem;border-radius:var(--ra);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;transition:all .2s;align-self:flex-start}
.bsv:hover{background:var(--am);border-color:var(--am)}

/* GALLERY / CAROUSEL */
.carousel{position:relative;border-radius:6px;overflow:hidden;box-shadow:var(--sh)}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-slide{flex:0 0 100%;aspect-ratio:16/9;position:relative}
.carousel-slide img{width:100%;height:100%;object-fit:cover}
.carousel-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(15,36,25,.85),transparent);color:#fff;padding:1.4rem;font-family:var(--se);font-size:.95rem}
.carousel-arrows{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;transform:translateY(-50%);padding:0 .8rem;z-index:5}
.carousel-arrows button{width:38px;height:38px;border-radius:50%;background:rgba(15,36,25,.55);color:#fff;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.carousel-arrows button:hover{background:var(--am)}
.carousel-dots{position:absolute;bottom:.8rem;left:0;right:0;display:flex;justify-content:center;gap:.4rem;z-index:5}
.carousel-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:background .2s}
.carousel-dots span.active{background:var(--am)}
.ggrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:2.8rem}
.gitem{aspect-ratio:1;border-radius:var(--ra);overflow:hidden;position:relative;cursor:pointer}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gitem:hover img{transform:scale(1.06)}

/* VIDEOS */
.vgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:2.8rem}
.vcard{border-radius:var(--ra);overflow:hidden;box-shadow:var(--sh);background:var(--wh)}
.vwrap{position:relative;aspect-ratio:16/9;background:var(--cd)}
.vwrap iframe,.vwrap video{position:absolute;inset:0;width:100%;height:100%;border:0}
.vinfo{padding:1.1rem 1.3rem}
.vinfo h3{font-family:var(--se);font-size:1rem;color:var(--td);font-weight:500;margin-bottom:.3rem}
.vinfo p{font-size:.82rem;color:var(--mid)}

/* ARTICLES */
.agd{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.8rem;margin-top:2.8rem}
.ac{background:var(--wh);border-radius:var(--ra);overflow:hidden;box-shadow:var(--sh);transition:all .25s;cursor:pointer;position:relative;display:block}
.ac:hover{transform:translateY(-4px);box-shadow:var(--sl)}
.ath{height:188px;background:linear-gradient(135deg,var(--tp),var(--cd));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.ath img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.acat{position:absolute;top:.9rem;left:.9rem;background:var(--am);color:var(--wh);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;padding:.28rem .65rem;border-radius:2px;z-index:2}
.ab{padding:1.4rem}
.am2{font-size:.68rem;color:var(--lt);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.65rem;display:flex;gap:.9rem;flex-wrap:wrap}
.atl{font-family:var(--se);font-size:1.15rem;color:var(--td);line-height:1.33;margin-bottom:.65rem;font-weight:500}
.aex{font-size:.83rem;color:var(--mid);line-height:1.7;margin-bottom:1.1rem}
.arm{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--am);font-weight:500;display:flex;align-items:center;gap:.35rem;transition:gap .2s}
.ac:hover .arm{gap:.6rem}

/* TESTIMONIALS */
.tbg{background:var(--cd)}
.tcarousel{margin-top:2.8rem;position:relative;overflow:hidden}
.ttrack{display:flex;transition:transform .5s ease}
.tslide{flex:0 0 100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.4rem;padding:.2rem}
.tc{background:var(--wh);border-radius:var(--ra);padding:1.8rem;box-shadow:var(--sh);position:relative}
.tc::before{content:'"';font-family:var(--ds);font-size:4.5rem;color:var(--tp);position:absolute;top:-.4rem;left:1.4rem;line-height:1}
.tt{font-family:var(--se);font-size:.97rem;color:var(--td);line-height:1.78;font-style:italic;margin-bottom:1.4rem}
.tau{display:flex;align-items:center;gap:.85rem}
.tav{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--tl));display:flex;align-items:center;justify-content:center;font-family:var(--se);font-size:.95rem;color:var(--wh);flex-shrink:0}
.tnm{font-size:.85rem;font-weight:500;color:var(--ch)}
.torg{font-size:.72rem;color:var(--lt)}
.stars{color:var(--am);font-size:.88rem;margin-bottom:.75rem}
.tdots{display:flex;justify-content:center;gap:.4rem;margin-top:1.4rem}
.tdots span{width:8px;height:8px;border-radius:50%;background:var(--lt);cursor:pointer;transition:background .2s}
.tdots span.active{background:var(--am)}

/* FAQ */
.flist{max-width:720px;margin:2.2rem auto 0;display:flex;flex-direction:column;gap:.75rem}
.fi{background:var(--wh);border-radius:var(--ra);box-shadow:var(--sh);overflow:hidden}
.fq{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 1.4rem;cursor:pointer;font-weight:500;color:var(--td);transition:background .2s;font-size:.92rem}
.fq:hover{background:var(--tp)}
.fqi{font-size:1.3rem;color:var(--teal);transition:transform .3s;flex-shrink:0;margin-left:.8rem}
.fi.open .fqi{transform:rotate(45deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .35s ease}
.fai{padding:0 1.4rem 1.2rem;font-size:.88rem;color:var(--mid);line-height:1.75}

/* NEWSLETTER */
.nbg{background:linear-gradient(135deg,var(--canopy-deep) 0%,var(--ocean) 100%)}
.nw{max-width:580px;margin:0 auto;text-align:center}
.nw .ey{justify-content:center}.nw .st{color:var(--wh)}.nw .sl{color:rgba(255,255,255,.68);margin:0 auto 1.8rem}
.nform{display:flex;gap:.75rem}
.ni{flex:1;padding:.82rem 1.1rem;border-radius:var(--ra);border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.09);color:var(--wh);font-size:.88rem;outline:none;transition:border-color .2s}
.ni::placeholder{color:rgba(255,255,255,.42)}.ni:focus{border-color:var(--al)}
.nb{background:var(--am);color:var(--wh);padding:.82rem 1.4rem;border-radius:var(--ra);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:all .2s;white-space:nowrap}
.nb:hover{background:var(--al)}
.nnote{font-size:.72rem;color:rgba(255,255,255,.42);margin-top:.8rem}

/* ARTICLES PAGE */
.arhero{background:linear-gradient(135deg,var(--canopy-deep),var(--ocean));padding:calc(70px + 3rem) 5vw 3.5rem;text-align:center}
.arhero h1{font-family:var(--ds);font-size:clamp(2rem,4.5vw,3rem);color:var(--wh);font-weight:400;margin-bottom:.7rem}
.arhero p{color:rgba(255,255,255,.68);max-width:500px;margin:0 auto}
.afltr{display:flex;gap:.55rem;flex-wrap:wrap;justify-content:center;margin-top:1.4rem}
.fbtn{padding:.42rem .95rem;border-radius:50px;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border:1.5px solid rgba(255,255,255,.22);color:rgba(255,255,255,.68);background:transparent;transition:all .2s}
.fbtn.active,.fbtn:hover{background:var(--am);border-color:var(--am);color:var(--wh)}
.armain{max-width:1160px;margin:2.5rem auto;padding:0 5vw 5rem}
.sbar{display:flex;gap:.75rem;margin-bottom:2.2rem}
.si2{flex:1;padding:.82rem 1.1rem;border:1.5px solid var(--cd);border-radius:var(--ra);font-size:.88rem;outline:none;background:var(--wh);transition:border-color .2s}
.si2:focus{border-color:var(--teal)}
.sb2{background:var(--teal);color:var(--wh);padding:.82rem 1.4rem;border-radius:var(--ra);font-size:.82rem;transition:background .2s}
.sb2:hover{background:var(--tl)}
.feat{background:var(--wh);border-radius:var(--ra);box-shadow:var(--sh);display:grid;grid-template-columns:1fr;overflow:hidden;margin-bottom:2.2rem;cursor:pointer;transition:all .25s;position:relative}
.feat:hover{box-shadow:var(--sl);transform:translateY(-2px)}
.fth{background:linear-gradient(135deg,var(--td),var(--tl));display:flex;align-items:center;justify-content:center;min-height:260px;position:relative;overflow:hidden}
.fth img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.flbl{position:absolute;top:.9rem;left:.9rem;background:var(--am);color:var(--wh);font-size:.67rem;letter-spacing:.14em;text-transform:uppercase;padding:.28rem .65rem;border-radius:2px;z-index:2}
.fbd{padding:2.2rem;display:flex;flex-direction:column;justify-content:center}

/* ARTICLE FULL PAGE */
.artback{padding:1rem 5vw;background:var(--cd)}
.artback a{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);display:inline-flex;align-items:center;gap:.4rem}
#art-cover-hero{width:100%;height:46vh;min-height:320px;max-height:520px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
#art-cover-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
#art-cover-hero .cover-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,30,28,.92) 0%,rgba(10,30,28,.5) 40%,rgba(10,30,28,.1) 70%,transparent 100%)}
#art-cover-hero .cover-content{position:relative;z-index:2;padding:2rem 5vw 2.5rem;max-width:900px;margin:0 auto;width:100%}
#art-cover-hero .cover-cat{display:inline-block;background:var(--am);color:var(--wh);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:.3rem .75rem;border-radius:2px;margin-bottom:1.1rem}
#art-cover-hero .cover-title{font-family:var(--ds);font-size:clamp(1.9rem,4.5vw,3.2rem);color:var(--wh);line-height:1.1;font-weight:400;margin-bottom:1rem;text-shadow:0 2px 20px rgba(0,0,0,.4)}
#art-cover-hero .cover-meta{font-size:.8rem;color:rgba(255,255,255,.65);letter-spacing:.1em;display:flex;gap:1.5rem;flex-wrap:wrap}
#art-cover-hero .cover-meta span{display:flex;align-items:center;gap:.35rem}
.artbody{max-width:740px;margin:0 auto;padding:3rem 5vw 5rem}
.artfulltt{font-family:var(--ds);font-size:clamp(1.8rem,3.8vw,2.7rem);color:var(--td);margin-bottom:.9rem;font-weight:400;line-height:1.14}
.artmeta{display:flex;gap:1.3rem;font-size:.75rem;color:var(--lt);letter-spacing:.08em;flex-wrap:wrap;margin-bottom:1.8rem}
.artcnt{font-family:var(--se);font-size:1.06rem;line-height:1.88;color:var(--ch)}
.artcnt p{margin-bottom:1.25rem}
.artcnt h2{font-family:var(--ds);font-size:1.4rem;color:var(--td);margin:1.8rem 0 .75rem;font-weight:400}
.artcnt img{border-radius:var(--ra);margin:1.4rem 0}
.artcta{background:var(--tp);border-radius:var(--ra);padding:1.8rem;margin-top:2.8rem;text-align:center}
.artcta h3{font-family:var(--se);font-size:1.25rem;color:var(--td);margin-bottom:.6rem}
.artcta p{font-size:.85rem;color:var(--mid);margin-bottom:1.1rem}
.shbtns{display:flex;gap:.55rem;margin-top:1.8rem;flex-wrap:wrap;align-items:center}
.shbtn{padding:.45rem .9rem;border-radius:var(--ra);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:.35rem;background:var(--cd);color:var(--mid);transition:all .2s;cursor:pointer;border:none}
.shbtn:hover{background:var(--tp);color:var(--teal)}
.shbtn .icon{width:14px;height:14px}
.engage-row{display:flex;gap:1rem;align-items:center;margin-top:1.2rem;flex-wrap:wrap}
.eng-btn{display:flex;align-items:center;gap:.4rem;background:var(--wh);border:1.5px solid var(--cd);color:var(--mid);padding:.5rem 1rem;border-radius:50px;font-size:.8rem;transition:all .2s}
.eng-btn:hover,.eng-btn.liked{border-color:var(--am);color:var(--am)}
.eng-btn .icon{width:16px;height:16px}
.eng-btn.liked .icon{fill:var(--am)}

/* BOOKING */
.bkhero{background:linear-gradient(135deg,var(--canopy-deep),var(--canopy));padding:calc(70px + 3rem) 5vw 3.5rem;text-align:center}
.bkhero h1{font-family:var(--ds);font-size:clamp(2rem,4.5vw,3rem);color:var(--wh);font-weight:400;margin-bottom:.7rem}
.bkhero p{color:rgba(255,255,255,.68);max-width:500px;margin:0 auto}
.bkwrap{max-width:880px;margin:2.5rem auto;padding:0 5vw 5rem}
.bksteps{display:flex;gap:.9rem;margin-bottom:2.2rem;flex-wrap:wrap;align-items:center}
.bkstep{display:flex;align-items:center;gap:.55rem;font-size:.78rem;color:var(--td);font-weight:500}
.stnum{width:24px;height:24px;border-radius:50%;background:var(--teal);color:var(--wh);display:flex;align-items:center;justify-content:center;font-size:.7rem;flex-shrink:0}
.stdiv{flex:1;height:1px;background:var(--cd);min-width:8px}
.bkgrid{display:grid;grid-template-columns:1fr;gap:1.8rem}
.bkcard{background:var(--wh);border-radius:var(--ra);padding:1.8rem;box-shadow:var(--sh);margin-bottom:1.5rem}
.bkcard h3{font-family:var(--se);font-size:1.15rem;color:var(--td);margin-bottom:1.2rem;font-weight:500}
.sopt{display:flex;gap:.9rem;padding:.95rem;border:1.5px solid var(--cd);border-radius:var(--ra);margin-bottom:.75rem;cursor:pointer;transition:all .2s;align-items:flex-start}
.sopt:hover,.sopt.sel{border-color:var(--teal);background:var(--tp)}
.sopt input{margin-top:.2rem;accent-color:var(--teal)}
.soptt strong{display:block;font-size:.88rem;color:var(--td);margin-bottom:.18rem}
.soptt span{font-size:.78rem;color:var(--mid)}
.sopp{font-family:var(--se);font-size:.97rem;color:var(--am);margin-left:auto;white-space:nowrap;align-self:center}
.fg{margin-bottom:1.1rem}
.fl{display:block;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:.45rem;font-weight:500}
.fi2,.fta,.fsel{width:100%;padding:.72rem .95rem;border-radius:var(--ra);border:1.5px solid var(--cd);font-size:.88rem;color:var(--ch);background:var(--wh);transition:border-color .2s;outline:none}
.fi2:focus,.fta:focus,.fsel:focus{border-color:var(--teal)}
.fta{resize:vertical;min-height:95px}
.bbk{width:100%;background:var(--teal);color:var(--wh);padding:.95rem;border-radius:var(--ra);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:all .2s;margin-top:.9rem;display:flex;align-items:center;justify-content:center;gap:.5rem}
.bbk:hover{background:var(--tl)}
.formnote{font-size:.78rem;color:var(--mid);margin-top:.6rem;line-height:1.6}
.errlist{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:.9rem 1.1rem;border-radius:var(--ra);font-size:.83rem;margin-bottom:1.2rem}
.successbox{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46;padding:1.2rem 1.4rem;border-radius:var(--ra);font-size:.9rem;margin-bottom:1.4rem;display:flex;flex-direction:column;gap:.7rem}

/* CONTACT */
.cgrid{display:grid;grid-template-columns:1fr;gap:1.8rem}
.cinfo{display:flex;flex-direction:column;gap:1rem}
.cinfo-item{display:flex;gap:.9rem;align-items:flex-start;background:var(--wh);border-radius:var(--ra);padding:1.1rem 1.3rem;box-shadow:var(--sh)}
.cinfo-item .cicon{background:var(--ocean)}
.cinfo-item div strong{display:block;color:var(--td);font-size:.88rem;margin-bottom:.15rem}
.cinfo-item div span{font-size:.82rem;color:var(--mid)}

/* FOOTER */
footer{background:var(--canopy-deep);padding:3.5rem 5vw 1.8rem;color:rgba(255,255,255,.62);border-top:1px solid rgba(110,168,130,.1)}
.fgrid{display:grid;grid-template-columns:1fr;gap:2.8rem;max-width:1160px;margin:0 auto 2.8rem}
.fbn{font-family:var(--se);font-size:1.15rem;color:var(--wh);font-weight:500;margin-bottom:.25rem}
.fbs{font-size:.67rem;color:rgba(255,255,255,.42);letter-spacing:.18em;text-transform:uppercase;margin-bottom:.9rem}
.ftag{font-size:.83rem;line-height:1.72;color:rgba(255,255,255,.52)}
.fct{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--al);margin-bottom:.9rem}
.fls{display:flex;flex-direction:column;gap:.45rem}
.fls a{font-size:.83rem;color:rgba(255,255,255,.52);transition:color .2s}
.fls a:hover{color:var(--al)}
.fsoc{display:flex;gap:.75rem;margin-top:.9rem}
.soci{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;transition:all .2s;color:rgba(255,255,255,.55)}
.soci:hover{border-color:var(--am);color:var(--am)}
.soci .icon{width:15px;height:15px}
.fni{display:flex;gap:.45rem;margin-top:.75rem}
.fni input{flex:1;padding:.58rem .88rem;border-radius:var(--ra);border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.06);color:var(--wh);font-size:.8rem;outline:none}
.fni input::placeholder{color:rgba(255,255,255,.32)}
.fni button{background:var(--am);color:var(--wh);padding:.58rem .95rem;border-radius:var(--ra);font-size:.73rem;transition:background .2s}
.fni button:hover{background:var(--al)}
.fbot{border-top:1px solid rgba(255,255,255,.07);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;max-width:1160px;margin:0 auto;font-size:.72rem;color:rgba(255,255,255,.32);flex-wrap:wrap;gap:.75rem}
.flg{display:flex;gap:1.1rem}
.flg a{color:rgba(255,255,255,.32);transition:color .2s}
.flg a:hover{color:rgba(255,255,255,.6)}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:1.6rem;right:1.6rem;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:var(--sl);z-index:900;color:#fff;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float .icon{width:28px;height:28px;stroke:none;fill:currentColor}

/* TOAST */
.toast{position:fixed;bottom:1.8rem;right:1.8rem;background:var(--td);color:var(--wh);padding:.95rem 1.4rem;border-radius:var(--ra);box-shadow:var(--sl);font-size:.85rem;z-index:9999;transform:translateY(100px);opacity:0;transition:all .35s;max-width:300px;display:flex;align-items:center;gap:.6rem}
.toast.show{transform:translateY(0);opacity:1}
.toast .icon{width:18px;height:18px;flex-shrink:0;color:var(--celadon)}

/* ADVERTS */
.ad-popup-overlay{position:fixed;inset:0;background:rgba(15,36,25,.55);z-index:1100;display:flex;align-items:center;justify-content:center;padding:1.2rem}
.ad-popup{background:var(--wh);border-radius:var(--ra);max-width:440px;width:100%;overflow:hidden;box-shadow:var(--sl);position:relative}
.ad-popup img{width:100%;aspect-ratio:16/9;object-fit:cover}
.ad-popup-body{padding:1.4rem}
.ad-popup-body h3{font-family:var(--se);font-size:1.15rem;color:var(--td);margin-bottom:.5rem}
.ad-popup-body p{font-size:.85rem;color:var(--mid);margin-bottom:1.1rem;line-height:1.7}
.ad-close{position:absolute;top:.7rem;right:.7rem;width:30px;height:30px;border-radius:50%;background:rgba(15,36,25,.6);color:#fff;display:flex;align-items:center;justify-content:center;z-index:2;cursor:pointer}
.ad-hanging{position:fixed;top:50%;transform:translateY(-50%);width:140px;z-index:850;box-shadow:var(--sl);border-radius:var(--ra);overflow:hidden;background:var(--wh)}
.ad-hanging.left{left:.8rem}.ad-hanging.right{right:.8rem}
.ad-hanging img{width:100%;display:block}
.ad-hanging .ad-close{width:22px;height:22px;font-size:.75rem}
.ad-bottom-bar{position:fixed;bottom:0;left:0;right:0;background:var(--td);color:#fff;padding:.85rem 1.2rem;display:flex;align-items:center;justify-content:center;gap:1rem;z-index:850;flex-wrap:wrap;text-align:center;box-shadow:0 -4px 24px rgba(0,0,0,.18)}
.ad-bottom-bar a{color:var(--al);text-decoration:underline}
@media(max-width:899px){.ad-hanging{display:none}}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.fu{animation:fadeUp .7s ease both}.d1{animation-delay:.1s}.d2{animation-delay:.22s}.d3{animation-delay:.38s}.d4{animation-delay:.52s}

/* ── TABLET (600px+) ── */
@media(min-width:600px){
 .sgrid{grid-template-columns:repeat(2,1fr)}
 .agd{grid-template-columns:repeat(2,1fr)}
 .ggrid{grid-template-columns:repeat(3,1fr)}
 .vgrid{grid-template-columns:repeat(2,1fr)}
 .fgrid{grid-template-columns:1fr 1fr}
 .feat{grid-template-columns:1fr 1fr}
 .cgrid{grid-template-columns:1fr 1fr}
}

/* ── DESKTOP (900px+) ── */
@media(min-width:900px){
 .nlinks{display:flex}
 .hbg{display:none}
 .hcont{padding:5rem 5vw 4rem;text-align:left;grid-template-columns:1.1fr .9fr}
 .hcont.no-media{grid-template-columns:1fr;max-width:780px;margin:0 auto;text-align:center}
 .hcont .hbtns{justify-content:flex-start}
 .hcont.no-media .hbtns,.hcont.no-media .hey{justify-content:center}
 .hero h1,.hsub{text-align:left}
 .hcont.no-media .hero h1,.hcont.no-media .hsub{text-align:center}
 .hero h1{font-size:clamp(2.8rem,4.5vw,3.9rem)}
 .agrid{grid-template-columns:1fr 1fr}
 .sgrid{grid-template-columns:repeat(4,1fr)}
 .agd{grid-template-columns:repeat(3,1fr)}
 .ggrid{grid-template-columns:repeat(4,1fr)}
 .vgrid{grid-template-columns:repeat(3,1fr)}
 .fgrid{grid-template-columns:2fr 1fr 1fr 1.4fr}
 .sec{padding:5.5rem 5vw}
 .bkgrid{grid-template-columns:1fr 1.15fr}
 .cgrid{grid-template-columns:1fr 1fr}
 #art-cover-hero{height:60vh}
}

@media(max-width:899px){.nlinks{display:none}.hbg{display:flex}}