/* ==============================================
   HerrMittmann — Hotellfotograf Bergen
   Bold Architectural Atelier / Cinematic Calm
   ============================================== */

:root {
  --bg: #eae6df;
  --bg2: #f4f1ec;
  --dark: #141311;
  --dark2: #1e1c19;
  --ink: #26231f;
  --ink2: #5c564e;
  --cream: #f4f1ec;
  --gold: #9a7f5a;
  --gold-l: #c4a97a;
  --gold-d: #6e5a3e;
  --glass: rgba(244,241,236,.55);
  --glass-b: rgba(20,19,17,.6);
  --R: 22px;
  --Rs: 14px;
  --ease: cubic-bezier(.22,1,.36,1);
  --max: 1280px;
  --hdr: 68px;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Maven Pro',sans-serif;font-weight:400;font-size:16.5px;line-height:1.72;color:var(--ink);background:var(--bg);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit}
figure{margin:0}
figcaption{font-size:.7rem;color:var(--ink2);margin-top:5px;opacity:.6}
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,5vw,64px)}

/* TYPOGRAPHY */
.h-jost{font-family:'Jost',sans-serif;font-weight:600}
.h-vollkorn{font-family:'Vollkorn',serif;font-weight:400;font-style:italic}
h2{font-size:clamp(1.7rem,3.8vw,3rem);line-height:1.18;letter-spacing:-.025em;margin-bottom:1.4rem}

/* NOISE TEXTURE (reused) */
.hero-noise,.sec-local::before,.sec-cta::before,.sec-contact::before{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  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='.035'/%3E%3C/svg%3E");
  background-size:256px;
}

/* BUTTONS */
.btn-prim{
  display:inline-flex;align-items:center;gap:8px;
  padding:17px 44px;
  font-family:'Jost',sans-serif;font-weight:600;font-size:.92rem;letter-spacing:.04em;
  color:var(--cream);background:var(--dark);
  border-radius:60px;position:relative;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
  box-shadow:0 4px 24px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.05);
}
.btn-prim::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 60%);pointer-events:none}
.btn-prim:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 40px rgba(0,0,0,.22)}
.btn-prim--light{background:var(--gold);color:#fff}
.btn-prim--light:hover{background:var(--gold-l)}
.btn-ghost{
  display:inline-block;padding:12px 30px;
  font-family:'Jost',sans-serif;font-weight:500;font-size:.88rem;letter-spacing:.03em;
  border:1.5px solid var(--gold);border-radius:60px;color:var(--ink);
  transition:all .4s var(--ease);
}
.btn-ghost:hover{background:var(--gold);color:#fff;border-color:var(--gold)}

/* REVEAL */
.rv{opacity:0;transform:translateY(50px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.rv.vis{opacity:1;transform:none}
.rvd1{transition-delay:.14s}
.rvd2{transition-delay:.28s}

/* ANIM-UP (hero specific) */
.anim-up{opacity:0;transform:translateY(60px);animation:slideUp 1s var(--ease) forwards}
.ad1{animation-delay:.25s}.ad2{animation-delay:.4s}.ad3{animation-delay:.55s}.ad4{animation-delay:.7s}.ad5{animation-delay:.9s}
@keyframes slideUp{to{opacity:1;transform:none}}

/* ==============================================
   HEADER
   ============================================== */
.hdr{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--hdr);transition:transform .55s var(--ease),background .4s ease,backdrop-filter .4s ease}
.hdr.scrolled{background:rgba(234,230,223,.82);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 1px 0 rgba(0,0,0,.06)}
.hdr.up{transform:translateY(-100%)}
.hdr-inner{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,5vw,64px);height:100%;display:flex;align-items:center;gap:24px}
.hdr-logo{margin-right:auto}
.hdr-logo img{height:26px;width:auto}
.hdr:not(.scrolled) .hdr-logo img{filter: brightness(0) invert(1);}
.hdr-nav{display:flex;gap:28px;font-family:'Jost',sans-serif;font-weight:500;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase}
.hdr-nav a{position:relative;padding:4px 0}
.hdr:not(.scrolled) .hdr-nav a{color:white}
.hdr-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--gold);transition:width .45s var(--ease)}
.hdr-nav a:hover::after{width:100%}
.hdr-cta{font-family:'Jost',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;padding:9px 22px;background:var(--dark);color:var(--cream);border-radius:60px;transition:transform .3s var(--ease);box-shadow:0 2px 8px rgba(0,0,0,.12)}
.hdr-cta:hover{transform:translateY(-1px)}
.hdr-burger{display:none;flex-direction:column;gap:6px;padding:6px}
.hdr-burger span{display:block;width:26px;height:1.5px;background:var(--ink);transition:all .3s ease}
@media(max-width:860px){
  .hdr-nav,.hdr-cta{display:none}
  .hdr-nav.open{display:flex;flex-direction:column;position:absolute;top:var(--hdr);left:0;right:0;background:rgba(234,230,223,.97);backdrop-filter:blur(20px);padding:28px clamp(20px,5vw,64px);gap:18px;text-transform:none;font-size:1rem;box-shadow:0 8px 30px rgba(0,0,0,.08)}
  .hdr-burger{display:flex}
}


/* ==============================================
   1. HERO — cinematic, image constrained to 1280px
   ============================================== */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;background:var(--dark)}
.hero-noise{z-index:2}
.hero-bg-glow{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse at 30% 40%,rgba(154,127,90,.15),transparent 60%),radial-gradient(ellipse at 70% 70%,rgba(196,169,122,.1),transparent 50%)}
.hero-inner{position:relative;z-index:3;max-width:var(--max);width:100%;padding:calc(var(--hdr) + 48px) clamp(24px,6vw,80px) 0;display:flex;flex-direction:column}
.hero-content{max-width:780px;margin-bottom:48px}
.hero-tag{font-family:'Jost',sans-serif;font-weight:400;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-l);margin-bottom:20px}
.hero-h1{margin-bottom:28px}
.hero-h1 .line{display:block}
.hero-h1 .h-jost{font-size:clamp(2.6rem,6.5vw,5rem);line-height:1.06;letter-spacing:-.03em;color:#fff}
.hero-h1 .h-vollkorn{font-size:clamp(2.6rem,6.5vw,5rem);line-height:1.06;letter-spacing:-.01em;color:var(--gold-l)}
.hero-sub{font-size:clamp(.95rem,1.6vw,1.12rem);color:rgba(255,255,255,.6);max-width:520px;line-height:1.75;margin-bottom:40px}
.hero-fig{width:100%;border-radius:var(--R);overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.35),0 4px 20px rgba(0,0,0,.2);margin-bottom:0}
.hero-photo{width:100%;aspect-ratio:2/1;object-fit:cover;display:block;transition:transform 8s var(--ease)}
.hero-fig:hover .hero-photo{transform:scale(1.03)}
.hero-scroll{position:relative;z-index:3;margin-top:40px;align-self:center;padding-bottom:32px}
.hero-scroll-bar{width:1px;height:48px;background:linear-gradient(to bottom,var(--gold-l),transparent);position:relative;overflow:hidden}
.hero-scroll-bar::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%{top:-100%}50%{top:100%}100%{top:100%}}

/* Screen-reader only */
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}

/* ==============================================
   2. USP
   ============================================== */
.sec-usp{padding:clamp(72px,9vw,130px) 0;background:var(--bg2)}
.kicker{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.usp-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.usp-card{padding:32px 24px 28px;background:var(--glass);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.7);border-radius:var(--R);box-shadow:0 1px 6px rgba(0,0,0,.03),inset 0 1px 0 rgba(255,255,255,.85);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.usp-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.08)}
.usp-n{font-family:'Vollkorn',serif;font-style:italic;font-size:2.4rem;color:var(--gold-l);display:block;line-height:1;opacity:.45}
.usp-sep{width:32px;height:1px;background:var(--gold);opacity:.35;margin:14px 0 16px}
.usp-card p{font-size:.92rem;line-height:1.65}
@media(max-width:700px){.usp-row{grid-template-columns:1fr;gap:14px}}

/* ==============================================
   3. LOCAL CONTEXT
   ============================================== */
.sec-local{position:relative;padding:clamp(100px,14vw,220px) 0;background:var(--dark);color:var(--cream);overflow:hidden}
.sec-local::before{content:''}
.sec-local canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.12;z-index:0}
.sec-local .wrap{position:relative;z-index:2}
.local-flex{display:flex;gap:clamp(28px,4vw,64px);align-items:flex-start}
.local-letter{font-family:'Vollkorn',serif;font-size:clamp(6rem,14vw,12rem);line-height:.82;color:var(--gold);opacity:.15;flex-shrink:0;user-select:none}
.local-body{max-width:660px}
.local-body h2{color:var(--cream);font-size:clamp(2rem,4.5vw,3.6rem);margin-bottom:1.8rem}
.local-body p{font-size:1.02rem;line-height:1.82;opacity:.78}
@media(max-width:600px){.local-letter{display:none}}

/* ==============================================
   4. GALLERY — CSS grid mosaic
   ============================================== */
.sec-gallery{padding:clamp(72px,9vw,130px) 0 0;background:var(--bg)}
.gallery-h{text-align:center;font-size:clamp(2rem,5vw,3.8rem);margin-bottom:clamp(36px,5vw,64px)}
.gal-mosaic{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  grid-auto-rows:350px;
  gap:8px;
  padding:0 8px clamp(72px,9vw,130px);
}
.g-i{border-radius:var(--Rs);overflow:hidden;cursor:pointer;position:relative}
.g-i img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .6s ease}
.g-i:hover img{transform:scale(1.06);filter:brightness(1.05)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}
@media(max-width:600px){
  .gal-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .g-wide{grid-column:span 1}
  .g-tall{grid-row:span 2}
}

/* ==============================================
   5. YOUTUBE
   ============================================== */
.sec-vid{position:relative;padding:clamp(100px,14vw,200px) 0;background:var(--dark2);overflow:hidden}
.vid-strip{position:absolute;top:50%;left:0;transform:translateY(-50%);white-space:nowrap;font-family:'Jost',sans-serif;font-weight:700;font-size:clamp(5rem,12vw,10rem);color:rgba(255,255,255,.03);pointer-events:none;display:flex;z-index:0}
.vid-strip span{display:inline-block;animation:marquee 30s linear infinite}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.sec-vid .wrap{position:relative;z-index:1}
.sec-vid h2{color:var(--cream);text-align:center;margin-bottom:clamp(32px,4vw,56px)}
.vid-frame{max-width:940px;margin:0 auto;border-radius:var(--R);overflow:hidden;aspect-ratio:16/9;box-shadow:0 24px 80px rgba(0,0,0,.5);position:relative}
.vid-frame::before{content:'';position:absolute;inset:-1px;border-radius:var(--R);border:1px solid rgba(255,255,255,.08);pointer-events:none;z-index:1}
.vid-frame iframe{width:100%;height:100%;border:none}

/* ==============================================
   6. COMBINED MEDIA
   ============================================== */
.sec-cmp{position:relative;padding:clamp(80px,10vw,150px) 0;background:var(--bg2);overflow:hidden}
.sec-cmp::before{content:''}
.cmp-h{text-align:center;font-size:clamp(1.8rem,4vw,3.2rem);margin-bottom:clamp(36px,5vw,64px)}
.cmp-duo{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
/* B/A Slider — clean clip approach */
.cmp-ba{position:relative;overflow:hidden;cursor:ew-resize;aspect-ratio:3/2;border-radius:var(--R);box-shadow:0 12px 48px rgba(0,0,0,.12);user-select:none;-webkit-user-select:none}
.ba-layer{position:absolute;top:0;left:0;width:100%;height:100%}
.ba-layer img{display:block;width:100%;height:100%;object-fit:cover}
.ba-layer--after{z-index:1}
.ba-layer--before{z-index:2;clip-path:inset(0 50% 0 0)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;z-index:4;display:flex;flex-direction:column;align-items:center;pointer-events:none;transform:translateX(-50%)}
.ba-line{flex:1;width:2.5px;background:rgba(255,255,255,.85);border-radius:2px}
.ba-knob{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 2px 16px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--ink)}
.ba-tag{position:absolute;bottom:16px;font-family:'Jost',sans-serif;font-weight:600;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.9);z-index:5;padding:6px 14px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-radius:20px}
.ba-tag-l{left:14px}
.ba-tag-r{right:14px}
.cmp-gif{border-radius:var(--R);overflow:hidden;aspect-ratio:3/2;box-shadow:0 12px 48px rgba(0,0,0,.12)}
.cmp-gif img{width:100%;height:100%;object-fit:cover}
@media(max-width:700px){.cmp-duo{grid-template-columns:1fr}}

/* ==============================================
   7. PROBLEM SOLUTION
   ============================================== */
.sec-ps{padding:clamp(80px,10vw,140px) 0;background:var(--bg)}
.ps-grid{display:grid;grid-template-columns:40px 1fr;gap:36px;max-width:780px; margin:0 auto;}
.ps-rule{color:var(--gold);opacity:.3}
.ps-rule svg{width:2px;height:100%}
.ps-text h2{font-size:clamp(1.6rem,3.5vw,2.6rem)}
.ps-text p{margin-top:1.1rem;line-height:1.82;color:var(--ink2)}
@media(max-width:600px){.ps-grid{grid-template-columns:1fr}.ps-rule{display:none}}

/* ==============================================
   8. BENEFITS
   ============================================== */
.sec-ben{padding:clamp(80px,10vw,140px) 0;background:var(--dark);color:var(--cream)}
.sec-ben h2{color:var(--cream);text-align:center;margin-bottom:clamp(40px,5vw,64px)}
.ben-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ben-card{padding:40px 28px 36px;border-radius:var(--R);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);backdrop-filter:blur(4px);transition:transform .5s var(--ease),background .4s ease}
.ben-card:hover{transform:translateY(-8px);background:rgba(255,255,255,.07)}
.ben-ic{width:48px;height:48px;margin-bottom:22px;color:var(--gold-l)}
.ben-ic svg{width:100%;height:100%}
.ben-card h3{font-family:'Jost',sans-serif;font-weight:600;font-size:1.05rem;margin-bottom:10px;color:var(--cream)}
.ben-card p{font-size:.9rem;line-height:1.68;opacity:.6}
@media(max-width:700px){.ben-row{grid-template-columns:1fr}}

/* ==============================================
   9. FEATURES
   ============================================== */
.sec-feat{padding:clamp(80px,10vw,140px) 0;background:var(--bg2)}
.feat-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.feat-h{font-size:clamp(1.6rem,3.5vw,2.8rem)}
.feat-list{display:flex;flex-direction:column;gap:0}
.feat-r{display:flex;align-items:baseline;gap:20px;padding:20px 0;border-bottom:1px solid var(--gold);border-bottom-color:rgba(154,127,90,.15)}
.feat-n{font-family:'Vollkorn',serif;font-style:italic;font-size:1.3rem;color:var(--gold);opacity:.45;flex-shrink:0;min-width:32px}
.feat-r p{font-size:.95rem;line-height:1.6}
@media(max-width:700px){.feat-split{grid-template-columns:1fr}}

/* ==============================================
   10. SOCIAL PROOF
   ============================================== */
.sec-sp{padding:clamp(72px,9vw,120px) 0;background:var(--bg)}
.sec-sp h2{text-align:center}
.sp-p{text-align:center;max-width:600px;margin:0 auto 36px;color:var(--ink2);line-height:1.72}
.sp-fb{text-align:center;padding:36px 0;margin-bottom:20px}
.sp-fb h3{font-family:'Jost',sans-serif;font-weight:600;font-size:1.15rem;margin-bottom:6px}
.sp-fb p{color:var(--ink2);margin-bottom:16px}
.sec-sp>.wrap>.btn-ghost{display:block;margin:25px auto 0;max-width:220px;text-align:center}

/* ==============================================
   11. ABOUT
   ============================================== */
.sec-about{padding:clamp(80px,10vw,160px) 0;background:var(--bg2)}
.about-grid{display:grid;grid-template-columns:260px 1fr;gap:clamp(36px,5vw,80px);align-items:center}
.about-photo figure{border-radius:var(--R);overflow:hidden;box-shadow:0 16px 60px rgba(0,0,0,.13)}
.about-photo img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform 1.2s var(--ease)}
.about-photo:hover img{transform:scale(1.04)}
.about-text h2{font-size:clamp(2rem,4vw,3rem)}
.about-text p{line-height:1.82;color:var(--ink2);margin-bottom:.9rem}
.about-wink{font-family:'Vollkorn',serif;font-style:italic;color:var(--gold)!important;font-size:.98rem;margin-top:1.2rem!important;opacity:.75}
@media(max-width:700px){.about-grid{grid-template-columns:1fr}.about-photo{max-width:220px}}

/* ==============================================
   12. DRONE
   ============================================== */
.sec-drone{padding:clamp(80px,10vw,140px) 0 clamp(60px,8vw,100px);background:var(--dark);color:var(--cream)}
.sec-drone h2{color:var(--cream)}
.drone-p{max-width:600px;opacity:.7;margin-bottom:clamp(28px,4vw,44px);line-height:1.72}
.drone-rail{position:relative;overflow:hidden;padding:0 clamp(20px,5vw,64px)}
.drone-track{display:flex;gap:18px;transition:transform .65s var(--ease)}
.drone-card{flex:0 0 auto;width:min(380px,78vw);border-radius:var(--Rs);overflow:hidden;cursor:pointer}
.drone-card img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform .7s var(--ease)}
.drone-card:hover img{transform:scale(1.05)}
.drone-nav{display:flex;gap:10px;margin-top:20px;padding:0 clamp(20px,5vw,64px)}
.drone-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:var(--cream);transition:all .3s var(--ease)}
.drone-btn:hover{background:var(--gold);border-color:var(--gold)}

/* ==============================================
   13. FAQ
   ============================================== */
.sec-faq{padding:clamp(80px,10vw,140px) 0;background:var(--bg)}
.sec-faq h2{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.faq-list{max-width:740px;margin:0 auto}
.faq-i{border-bottom:1px solid rgba(154,127,90,.15)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;font-family:'Jost',sans-serif;font-weight:500;font-size:.98rem;color:var(--ink);text-align:left;transition:color .3s ease}
.faq-q:hover{color:var(--gold)}
.faq-x{width:18px;height:18px;position:relative;flex-shrink:0}
.faq-x::before,.faq-x::after{content:'';position:absolute;background:var(--gold);border-radius:2px;transition:transform .4s var(--ease)}
.faq-x::before{width:18px;height:1.5px;top:50%;left:0;transform:translateY(-50%)}
.faq-x::after{width:1.5px;height:18px;left:50%;top:0;transform:translateX(-50%)}
.faq-i.open .faq-x::after{transform:translateX(-50%) rotate(90deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .55s var(--ease),padding .55s var(--ease)}
.faq-i.open .faq-a{max-height:220px;padding-bottom:18px}
.faq-a p{font-size:.9rem;line-height:1.72;color:var(--ink2)}

/* ==============================================
   14. CTA
   ============================================== */
.sec-cta{position:relative;padding:clamp(120px,16vw,240px) 0;background:var(--dark);overflow:hidden}
.sec-cta::before{content:''}
.sec-cta canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.1;z-index:0}
.sec-cta .wrap{position:relative;z-index:2}
.cta-box{text-align:center;max-width:580px;margin:0 auto}
.cta-box h2{color:var(--cream);font-size:clamp(2.2rem,5vw,4rem)}
.cta-box p{color:rgba(244,241,236,.6);font-size:1.05rem;margin-bottom:2.2rem;line-height:1.72}

/* ==============================================
   15. CONTACT
   ============================================== */
.sec-contact{position:relative;padding:clamp(80px,10vw,150px) 0;background:var(--bg2);overflow:hidden}
.sec-contact::before{content:''}
.sec-contact canvas{position:absolute;inset:0;width:100%;height:100%;opacity:.06;z-index:0}
.sec-contact .wrap{position:relative;z-index:2}
.contact-core{text-align:center}
.contact-core h2{margin-bottom:clamp(28px,4vw,44px)}
.contact-pills{display:flex;flex-direction:column;align-items:center;gap:16px}
.cpill{display:inline-flex;align-items:center;gap:14px;padding:18px 36px;background:var(--glass);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.65);border-radius:var(--R);font-family:'Jost',sans-serif;font-weight:500;font-size:1.02rem;color:var(--ink);box-shadow:0 2px 12px rgba(0,0,0,.04),inset 0 1px 0 rgba(255,255,255,.8);transition:all .45s var(--ease)}
.cpill svg{color:var(--gold);flex-shrink:0}
.cpill:hover{transform:translateY(-4px);box-shadow:0 16px 50px rgba(0,0,0,.1);background:rgba(255,255,255,.8)}

/* ==============================================
   16. FOOTER
   ============================================== */
.foot{padding:44px 0;background:var(--dark)}
.foot-row{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.foot-logo img{height:20px;width:auto;filter:brightness(10);opacity:.6}
.foot-mid{display:flex;gap:24px;font-size:.82rem;color:rgba(244,241,236,.4)}
.foot-mid a:hover{color:var(--gold-l)}
.foot-legal{display:flex;gap:18px;font-size:.78rem;color:rgba(244,241,236,.3)}
.foot-legal a:hover{color:var(--gold-l)}
@media(max-width:600px){.foot-row{flex-direction:column;text-align:center}}

/* ==============================================
   LIGHTBOX
   ============================================== */
.lb{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.94);backdrop-filter:blur(24px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s ease;padding:40px}
.lb.open{opacity:1;pointer-events:all}
.lb-x{position:absolute;top:20px;right:28px;font-size:2.2rem;color:rgba(255,255,255,.6);transition:color .3s;z-index:10}
.lb-x:hover{color:#fff}
#lbImg{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--Rs);opacity:0;transform:scale(.94);transition:all .45s var(--ease)}
.lb.open #lbImg{opacity:1;transform:scale(1)}
