/* Tandvikaa Theme — Main Stylesheet */
/* Version: 1.0.0 */


/* ══════════════════════════════════════════
   DESIGN SYSTEM — 3D THEATRICAL STAGE
   Dark cinematic + gold + deep crimson
   Type: Playfair Display (display) + DM Sans
   Aesthetic: Luxury theatre / dance stage 3D
══════════════════════════════════════════ */
:root{
  --bg:        #08050F;
  --surface:   #100C1E;
  --card:      #150F28;
  --deep:      #1E1538;
  --gold:      #D4A017;
  --gold2:     #F5C842;
  --golddim:   #8A6400;
  --crimson:   #C0183A;
  --ember:     #E84C2B;
  --cream:     #FFF8E6;
  --ivory:     #F5EDD4;
  --text:      #E8DFC8;
  --muted:     #7A6E8A;
  --border:    rgba(212,160,23,.18);
  --glow:      rgba(212,160,23,.22);
  --serif:     'Playfair Display', Georgia, serif;
  --sans:      'DM Sans', sans-serif;
  --ease:      cubic-bezier(.25,.46,.45,.94);
  --spring:    cubic-bezier(.34,1.56,.64,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--sans);color:var(--text);
  background:var(--bg);overflow-x:hidden;
  cursor:default;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.page{display:none}.page.on{display:block}

/* ─── CUSTOM CURSOR (desktop) ─── */
@media(pointer:fine){
  body{cursor:none}
  #cursor{
    position:fixed;width:12px;height:12px;
    background:var(--gold2);border-radius:50%;
    pointer-events:none;z-index:99999;
    transform:translate(-50%,-50%);
    transition:transform .1s,width .25s,height .25s,background .25s;
    mix-blend-mode:difference;
  }
  #cursor.big{width:40px;height:40px;background:rgba(245,200,66,.25)}
}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}

/* ─── NOISE OVERLAY ─── */
body::before{
  content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.4;
}

/* ─── LAYOUT ─── */
.wrap{max-width:1320px;margin:0 auto;padding:0 2.5rem}
section{padding:8rem 0}
section.slim{padding:5rem 0}

/* ─── REVEAL ANIMATIONS ─── */
.fade-up{opacity:0;transform:translateY(48px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.fade-up.in{opacity:1;transform:translateY(0)}
.fade-in{opacity:0;transition:opacity .8s var(--ease)}
.fade-in.in{opacity:1}
.fade-left{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.fade-left.in{opacity:1;transform:translateX(0)}
.fade-right{opacity:0;transform:translateX(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.fade-right.in{opacity:1;transform:translateX(0)}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}.d5{transition-delay:.60s}

/* ─── LABELS ─── */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.65rem;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  margin-bottom:1rem;
}
.eyebrow::before,.eyebrow::after{content:'';display:block;width:16px;height:1px;background:var(--gold)}

h2.head{
  font-family:var(--serif);
  font-size:clamp(2.6rem,4.5vw,4.2rem);
  font-weight:700;color:var(--cream);line-height:1.05;
  letter-spacing:-.02em;margin-bottom:1.2rem;
}
h2.head em{font-style:italic;color:var(--gold2)}
h2.head-light{color:var(--bg)}
h2.head-light em{color:var(--crimson)}

.body-text{
  font-family:var(--sans);font-size:.98rem;color:var(--muted);
  line-height:1.9;font-weight:400;
}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.8rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.9rem 2rem;border-radius:100px;cursor:pointer;border:none;
  transition:all .4s var(--spring);position:relative;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:rgba(255,255,255,.12);transform:translateX(-110%);
  transition:transform .4s var(--ease);
}
.btn:hover::before{transform:translateX(0)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--ember) 100%);
  color:#fff;box-shadow:0 8px 32px rgba(212,160,23,.4),0 0 0 0 rgba(212,160,23,.3);
}
.btn-gold:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 16px 48px rgba(212,160,23,.55),0 0 40px rgba(212,160,23,.2)}
.btn-outline{
  background:transparent;color:var(--gold2);
  border:1.5px solid rgba(212,160,23,.4);
}
.btn-outline:hover{border-color:var(--gold);background:rgba(212,160,23,.07);transform:translateY(-2px)}
.btn-ghost{
  background:rgba(255,255,255,.05);color:var(--text);
  border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(12px);
}
.btn-ghost:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}

/* ════════════════════════════════════════
   NAVIGATION
════════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;width:100%;z-index:990;
  transition:all .5s var(--ease);
  padding:1.4rem 0;
}
#nav.scrolled{
  background:rgba(8,5,15,.88);
  backdrop-filter:blur(32px) saturate(1.5);
  border-bottom:1px solid var(--border);
  padding:.85rem 0;
  box-shadow:0 8px 64px rgba(0,0,0,.6);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-logo{display:flex;align-items:center;gap:.8rem;cursor:pointer}
.nav-logo-ring{
  width:46px;height:46px;border-radius:50%;
  border:2px solid var(--gold);padding:2px;
  background:rgba(212,160,23,.08);
  transition:all .4s var(--spring);
  position:relative;overflow:hidden;
}
.nav-logo-ring::before{
  content:'';position:absolute;inset:-2px;border-radius:50%;
  background:conic-gradient(from 0deg,transparent 70%,var(--gold2) 100%,transparent);
  animation:spin 4s linear infinite;opacity:0;transition:opacity .4s;
}
.nav-logo:hover .nav-logo-ring::before{opacity:1}
@keyframes spin{to{transform:rotate(360deg)}}
.nav-logo-ring img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.nav-logo:hover .nav-logo-ring{transform:scale(1.08);box-shadow:0 0 24px var(--glow)}
.nav-brand{display:flex;flex-direction:column;line-height:1}
.nav-name{
  font-family:var(--serif);font-size:1.1rem;font-weight:700;
  color:#fff;letter-spacing:.05em;
}
.nav-sub{
  font-family:var(--sans);font-size:.5rem;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
  margin-top:2px;
}
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none}
.nav-links a{
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
  padding:.55rem 1rem;border-radius:100px;
  transition:all .3s;position:relative;
}
.nav-links a:hover,.nav-links a.cur{color:#fff;background:rgba(255,255,255,.07)}
.nav-links a.cur{color:var(--gold2)}
.nav-cta{
  background:linear-gradient(135deg,var(--gold),var(--ember)) !important;
  color:#fff !important;padding:.55rem 1.4rem !important;
  font-weight:700 !important;border-radius:100px !important;
  box-shadow:0 4px 20px rgba(212,160,23,.35) !important;
}
.nav-cta.cur{color:#fff !important}
.nav-cta:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 8px 32px rgba(212,160,23,.55) !important}
.hamburger{display:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.7);border-radius:2px;transition:all .35s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{
  display:none;position:absolute;top:100%;left:0;width:100%;
  background:rgba(8,5,15,.97);backdrop-filter:blur(40px);
  border-bottom:1px solid var(--border);
  padding:1.5rem 2.5rem 2rem;
  flex-direction:column;gap:.5rem;
}
.mobile-menu a{
  font-family:var(--sans);font-size:1rem;font-weight:600;
  letter-spacing:.06em;color:rgba(255,255,255,.65);
  padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.06);
  transition:color .25s;
}
.mobile-menu a:hover,.mobile-menu a.cur{color:var(--gold2)}

/* ════════════════════════════════════════
   MOBILE BOTTOM QUICK-NAV
════════════════════════════════════════ */
#qnav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:989;
  background:rgba(8,5,15,.96);
  backdrop-filter:blur(40px) saturate(2);
  border-top:1px solid rgba(212,160,23,.2);
  padding:.5rem 0 env(safe-area-inset-bottom,.5rem);
  justify-content:space-around;align-items:stretch;
}
.qn-btn{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:.22rem;
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.35);
  padding:.42rem .6rem .3rem;
  border-radius:10px;min-width:52px;
  transition:all .25s var(--spring);
  position:relative;
}
.qn-btn.cur{color:var(--gold2)}
.qn-btn.cur::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:24px;height:2.5px;border-radius:0 0 3px 3px;
  background:linear-gradient(90deg,var(--gold),var(--gold2));
}
.qn-btn:active{transform:scale(.92)}
.qn-icon{font-size:1.35rem;line-height:1;display:block}
.qn-label{
  font-family:var(--sans);font-size:.52rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
}
.qn-book{
  background:linear-gradient(135deg,var(--gold),var(--ember)) !important;
  color:#fff !important;
  border-radius:14px !important;
  box-shadow:0 4px 18px rgba(212,160,23,.45);
  min-width:60px !important;
}
.qn-book.cur::before{display:none}
.qn-book:hover{transform:translateY(-2px) scale(1.05)}

/* ════════════════════════════════════════
   3D HERO — CINEMATIC STAGE
════════════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;overflow:hidden;
  background:var(--bg);padding-top:80px;
}

/* Layered theatrical background */
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-img{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1547153760-18fc86324498?w=1600&q=85') center/cover no-repeat;
  opacity:.18;transform:scale(1.05);
  animation:slow-zoom 20s ease-in-out infinite alternate;
}
@keyframes slow-zoom{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hero-bg-grad{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 90% 70% at 50% 100%, rgba(212,160,23,.06) 0%, transparent 70%),
    radial-gradient(ellipse 60% 50% at 20% 50%, rgba(192,24,58,.08) 0%, transparent 60%),
    linear-gradient(180deg, rgba(8,5,15,.85) 0%, rgba(8,5,15,.45) 40%, rgba(8,5,15,.95) 100%);
}

/* Vertical light shaft */
.hero-shaft{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:2px;height:100%;
  background:linear-gradient(to bottom, transparent 0%, rgba(212,160,23,.25) 30%, rgba(212,160,23,.08) 70%, transparent 100%);
  z-index:1;
}
/* Stage floor lines — perspective */
.hero-floor{
  position:absolute;bottom:0;left:0;right:0;height:340px;z-index:1;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(212,160,23,.04) 0px, rgba(212,160,23,.04) 1px,
      transparent 1px, transparent 80px
    );
  transform:perspective(600px) rotateX(55deg);
  transform-origin:bottom center;
  opacity:.7;
}

/* Floating particles */
.particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.par{
  position:absolute;width:2px;height:2px;border-radius:50%;
  background:var(--gold2);
  animation:float var(--d,8s) ease-in-out infinite;
  animation-delay:var(--delay,0s);opacity:0;
}
@keyframes float{
  0%{transform:translateY(100vh) translateX(0);opacity:0}
  10%{opacity:.6}
  90%{opacity:.3}
  100%{transform:translateY(-20vh) translateX(var(--dx,20px));opacity:0}
}

/* Hero content */
.hero-inner{
  position:relative;z-index:2;width:100%;
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:center;min-height:calc(100vh - 80px);
  padding:4rem 0 6rem;
}
.hero-left{max-width:600px}

.hero-tag{
  display:inline-flex;align-items:center;gap:.7rem;
  background:rgba(212,160,23,.08);border:1px solid rgba(212,160,23,.25);
  padding:.4rem 1rem;border-radius:100px;
  font-family:var(--sans);font-size:.65rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  margin-bottom:2rem;
  backdrop-filter:blur(12px);
}
.tag-dot{
  width:6px;height:6px;background:var(--gold2);border-radius:50%;
  box-shadow:0 0 8px var(--gold2);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 6px var(--gold2),0 0 0 0 rgba(245,200,66,.4)}50%{box-shadow:0 0 12px var(--gold2),0 0 0 8px rgba(245,200,66,0)}}

.hero-h1{
  font-family:var(--serif);
  font-size:clamp(3rem,5.5vw,5.8rem);
  font-weight:900;color:#fff;line-height:.95;
  letter-spacing:-.03em;margin-bottom:1.6rem;
}
.hero-h1 .line{display:block;overflow:hidden}
.hero-h1 .inner{display:block;transform:translateY(110%);animation:slide-up .9s var(--ease) forwards}
.hero-h1 .line:nth-child(1) .inner{animation-delay:.3s}
.hero-h1 .line:nth-child(2) .inner{animation-delay:.45s}
.hero-h1 .line:nth-child(3) .inner{animation-delay:.6s}
@keyframes slide-up{to{transform:translateY(0)}}
.hero-h1 em{font-style:italic;color:var(--gold2);text-shadow:0 0 40px rgba(245,200,66,.4)}
.hero-h1 .stroke{
  -webkit-text-stroke:2px rgba(212,160,23,.5);
  color:transparent;
}

.hero-body{
  font-family:var(--sans);font-size:1rem;color:rgba(232,223,200,.65);
  line-height:1.85;max-width:460px;font-weight:300;
  margin-bottom:2.5rem;
  animation:fade-in-body .9s ease .85s forwards;opacity:0;
}
@keyframes fade-in-body{to{opacity:1}}

.hero-ctas{
  display:flex;gap:1rem;flex-wrap:wrap;
  animation:fade-in-body .9s ease 1s forwards;opacity:0;
}

/* STATS ROW */
.hero-stats{
  display:flex;gap:0;margin-top:3.5rem;
  border:1px solid var(--border);border-radius:16px;
  background:rgba(255,255,255,.03);backdrop-filter:blur(16px);
  overflow:hidden;animation:fade-in-body .9s ease 1.1s forwards;opacity:0;
}
.hstat{
  flex:1;padding:1.2rem 1.5rem;text-align:center;
  border-right:1px solid var(--border);
  transition:background .3s;
}
.hstat:last-child{border-right:none}
.hstat:hover{background:rgba(212,160,23,.05)}
.hstat-n{
  font-family:var(--serif);font-size:2.2rem;font-weight:900;
  color:var(--gold2);line-height:1;letter-spacing:-.03em;
}
.hstat-l{
  font-family:var(--sans);font-size:.58rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(232,223,200,.4);margin-top:.35rem;
}

/* ── HERO RIGHT: 3D FLOATING CARD STACK ── */
.hero-visual{
  position:relative;height:580px;
  perspective:1000px;
  display:flex;align-items:center;justify-content:center;
}
/* 3D Card container */
.card3d-wrap{
  position:relative;width:380px;height:480px;
  transform-style:preserve-3d;
  animation:card-float 6s ease-in-out infinite;
}
@keyframes card-float{
  0%,100%{transform:rotateX(4deg) rotateY(-8deg) translateY(0)}
  50%{transform:rotateX(-2deg) rotateY(4deg) translateY(-16px)}
}
.card3d{
  position:absolute;border-radius:20px;overflow:hidden;
  box-shadow:
    0 40px 80px rgba(0,0,0,.7),
    0 0 0 1px rgba(255,255,255,.07),
    inset 0 1px 0 rgba(255,255,255,.12);
}
.card3d-main{
  width:340px;height:440px;top:20px;left:20px;
  background:#000;
  transform:translateZ(0);
}
.card3d-main img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.85) saturate(1.2);
  display:block;
}
/* Shimmer overlay on card */
.card3d-main::before{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 50%,rgba(212,160,23,.06) 100%);
  pointer-events:none;
}
.card3d-main::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:50%;z-index:3;
  background:linear-gradient(to top,rgba(8,5,15,.95) 0%,transparent 100%);
}
/* Info pill overlaid on card */
.card-info{
  position:absolute;bottom:0;left:0;right:0;z-index:4;
  padding:1.5rem;
  display:flex;align-items:flex-end;justify-content:space-between;
}
.card-text h3{
  font-family:var(--serif);font-size:1.4rem;font-weight:700;color:#fff;
  line-height:1.1;margin-bottom:.3rem;
}
.card-text p{
  font-family:var(--sans);font-size:.68rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
}
.card-badge{
  background:linear-gradient(135deg,var(--gold),var(--ember));
  color:#fff;padding:.4rem .9rem;border-radius:100px;
  font-family:var(--sans);font-size:.65rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 4px 16px rgba(212,160,23,.5);white-space:nowrap;
}

/* Behind cards */
.card3d-back1{
  width:280px;height:380px;right:-10px;bottom:-15px;
  background:linear-gradient(135deg,var(--deep),var(--card));
  border:1px solid var(--border);
  transform:translateZ(-40px) rotate(6deg);
  opacity:.7;
}
.card3d-back2{
  width:260px;height:350px;left:-15px;top:10px;
  background:linear-gradient(135deg,rgba(192,24,58,.15),rgba(8,5,15,.5));
  border:1px solid rgba(192,24,58,.2);
  transform:translateZ(-80px) rotate(-4deg);
  opacity:.5;
}

/* Floating badge outside cards */
.float-badge{
  position:absolute;
  background:rgba(8,5,15,.85);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:14px;padding:.9rem 1.3rem;
  animation:badge-float 5s ease-in-out infinite;
  box-shadow:0 8px 32px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08);
  z-index:5;
}
.float-badge h4{font-family:var(--serif);font-size:1.3rem;font-weight:700;color:var(--gold2);line-height:1}
.float-badge p{font-family:var(--sans);font-size:.6rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
.badge-top{top:-1.5rem;right:2rem;animation-delay:0s}
.badge-bot{bottom:2rem;left:-2rem;animation-delay:1.5s}
@keyframes badge-float{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%{transform:translateY(-10px) rotate(1deg)}
}

/* Stage rings — decorative backdrop */
.stage-ring{
  position:absolute;border-radius:50%;border:1px solid rgba(212,160,23,.07);
  pointer-events:none;
  animation:ring-breathe 6s ease-in-out infinite;
}
.ring1{width:600px;height:600px;top:50%;left:50%;transform:translate(-50%,-50%)}
.ring2{width:800px;height:800px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:2s}
.ring3{width:1000px;height:1000px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:4s}
@keyframes ring-breathe{0%,100%{opacity:.5}50%{opacity:1}}

/* ════════════════════════════════════════
   MARQUEE STRIP
════════════════════════════════════════ */
.marquee-strip{
  background:linear-gradient(135deg,var(--gold) 0%,var(--ember) 100%);
  padding:.9rem 0;overflow:hidden;position:relative;z-index:2;
}
.marquee-track{
  display:flex;gap:0;width:max-content;
  animation:marquee 28s linear infinite;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  font-family:var(--serif);font-size:1rem;font-weight:700;
  color:rgba(8,5,15,.85);white-space:nowrap;
  padding:0 2rem;display:flex;align-items:center;gap:2rem;
}
.marquee-item::after{content:'✦';color:rgba(8,5,15,.5)}

/* ════════════════════════════════════════
   ABOUT HOME — 3D SPLIT
════════════════════════════════════════ */
.about-sec{background:var(--surface);position:relative;overflow:hidden}
.about-sec::before{
  content:'';position:absolute;top:-200px;left:-200px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(212,160,23,.04) 0%, transparent 70%);
  pointer-events:none;
}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}

/* 3D image stack */
.about-visual{position:relative;height:560px;perspective:900px}
.av-main{
  position:absolute;inset:0;border-radius:16px;overflow:hidden;
  transform:perspective(900px) rotateY(8deg) rotateX(2deg);
  box-shadow:
    -40px 40px 80px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,255,255,.06),
    inset 0 1px 0 rgba(255,255,255,.1);
  transition:transform .8s var(--ease);
}
.about-visual:hover .av-main{transform:perspective(900px) rotateY(2deg) rotateX(-1deg)}
.av-main img{width:100%;height:100%;object-fit:cover;filter:brightness(.85) saturate(1.1)}
.av-main::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(150deg,rgba(212,160,23,.08) 0%,transparent 60%);
}
.av-card{
  position:absolute;bottom:-2rem;right:-2rem;z-index:3;
  background:var(--card);border:1px solid var(--border);
  border-radius:16px;padding:1.4rem 1.8rem;
  box-shadow:0 20px 60px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter:blur(20px);
  transform:perspective(400px) rotateX(-5deg) rotateY(-8deg);
  transition:transform .6s var(--ease);
}
.about-visual:hover .av-card{transform:perspective(400px) rotateX(-2deg) rotateY(-3deg)}
.av-card-num{
  font-family:var(--serif);font-size:3rem;font-weight:900;
  color:var(--gold2);line-height:1;
  text-shadow:0 0 30px rgba(245,200,66,.4);
}
.av-card-lbl{font-family:var(--sans);font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}

.about-content .body-text{margin-bottom:1.3rem;max-width:480px}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-top:2rem}
.feat{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  border-radius:12px;padding:1rem 1.2rem;
  transition:all .4s var(--ease);cursor:default;
}
.feat:hover{background:rgba(212,160,23,.06);border-color:var(--border);transform:translateY(-3px)}
.feat-icon{font-size:1.4rem;margin-bottom:.5rem}
.feat h4{font-family:var(--sans);font-size:.82rem;font-weight:700;color:var(--cream);margin-bottom:.2rem}
.feat p{font-family:var(--sans);font-size:.75rem;color:var(--muted);line-height:1.55}

/* ════════════════════════════════════════
   STYLES GRID — 3D HOVER CARDS
════════════════════════════════════════ */
.styles-sec{
  background:var(--bg);position:relative;overflow:hidden;
  padding-bottom:6rem;
}
.styles-sec::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.styles-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:4rem}
.s-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  perspective:1200px;
}
.s-card{
  background:var(--card);border:1px solid rgba(255,255,255,.06);
  border-radius:20px;padding:2.4rem 2rem;
  position:relative;overflow:hidden;cursor:default;
  transform-style:preserve-3d;
  transition:all .5s var(--ease);
  box-shadow:0 8px 40px rgba(0,0,0,.4);
}
.s-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(212,160,23,.06) 0%,transparent 60%);
  opacity:0;transition:opacity .4s;
}
.s-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 20px 20px;
  background:linear-gradient(90deg,var(--gold),var(--ember));
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
}
.s-card:hover{
  transform:translateY(-10px) rotateX(4deg) rotateY(-2deg);
  border-color:rgba(212,160,23,.2);
  box-shadow:0 32px 80px rgba(0,0,0,.5),0 0 0 1px rgba(212,160,23,.1),0 -8px 30px rgba(212,160,23,.06) inset;
}
.s-card:hover::before{opacity:1}
.s-card:hover::after{transform:scaleX(1)}
.s-num{
  font-family:var(--serif);font-size:4rem;font-weight:900;
  color:rgba(255,255,255,.04);line-height:1;margin-bottom:.8rem;
  transition:color .35s;letter-spacing:-.05em;
}
.s-card:hover .s-num{color:rgba(212,160,23,.15)}
.s-icon{font-size:2rem;margin-bottom:1rem;display:block;filter:drop-shadow(0 4px 12px rgba(212,160,23,.3))}
.s-name{
  font-family:var(--serif);font-size:1.5rem;font-weight:700;
  color:var(--cream);margin-bottom:.5rem;line-height:1.1;
  letter-spacing:-.02em;
}
.s-desc{
  font-family:var(--sans);font-size:.82rem;color:var(--muted);
  line-height:1.7;font-weight:300;
}
.s-tag{
  display:inline-block;margin-top:1rem;
  font-family:var(--sans);font-size:.6rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.28rem .8rem;border-radius:100px;
  background:rgba(212,160,23,.1);color:var(--gold);
  border:1px solid rgba(212,160,23,.2);
}

/* ════════════════════════════════════════
   FOUNDER SECTION — IMMERSIVE SPLIT
════════════════════════════════════════ */
.founder-sec{
  position:relative;overflow:hidden;background:var(--surface);
}
.founder-sec::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,160,23,.3),transparent);
}
.founder-grid{
  display:grid;grid-template-columns:5fr 7fr;
  min-height:680px;gap:0;
}
.founder-photo-col{
  position:relative;overflow:hidden;
}
.founder-photo-col img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;filter:brightness(.75) saturate(1.1);
  transition:transform .8s var(--ease);
}
.founder-sec:hover .founder-photo-col img{transform:scale(1.04)}
.founder-photo-col::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:180px;
  background:linear-gradient(to right,transparent,var(--surface));
}
.founder-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,5,15,.8) 0%,transparent 40%);
}
.founder-label{
  position:absolute;bottom:2rem;left:2rem;z-index:3;
  background:linear-gradient(135deg,var(--gold),var(--ember));
  color:var(--bg);padding:.75rem 1.4rem;border-radius:10px;
  box-shadow:0 8px 32px rgba(212,160,23,.4);
}
.founder-label p{font-family:var(--sans);font-size:.6rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;opacity:.7}
.founder-label h4{font-family:var(--serif);font-size:1.15rem;font-weight:700;margin-top:.1rem}

.founder-text{
  padding:5rem 4rem 5rem 3.5rem;
  display:flex;flex-direction:column;justify-content:center;
}
.founder-text .eyebrow{color:var(--gold)}
blockquote.founder-q{
  font-family:var(--serif);font-size:1.5rem;font-weight:400;font-style:italic;
  color:var(--cream);line-height:1.7;
  border-left:3px solid var(--gold);padding-left:1.8rem;
  margin:1.5rem 0 2rem;
  position:relative;
}
blockquote.founder-q::before{
  content:'\201C';position:absolute;top:-.5rem;left:-.5rem;
  font-size:5rem;color:rgba(212,160,23,.12);font-family:var(--serif);font-weight:900;line-height:1;
}
.founder-text .body-text{max-width:480px;margin-bottom:.9rem}
.founder-sig{
  display:flex;align-items:center;gap:1rem;margin-top:2rem;
  padding:1.1rem 1.5rem;background:rgba(255,255,255,.03);
  border:1px solid var(--border);border-radius:12px;
  width:fit-content;
}
.sig-img{
  width:44px;height:44px;border-radius:50%;
  object-fit:cover;border:2px solid var(--gold);
  box-shadow:0 0 16px rgba(212,160,23,.3);
}
.sig-n{font-family:var(--sans);font-size:.9rem;font-weight:700;color:var(--cream)}
.sig-r{font-family:var(--sans);font-size:.65rem;color:var(--gold);letter-spacing:.08em;margin-top:.1rem}

/* ════════════════════════════════════════
   TESTIMONIALS — 3D ANGLED CARDS
════════════════════════════════════════ */
.testi-sec{
  background:var(--bg);position:relative;overflow:hidden;
}
.testi-sec::before{
  content:'';position:absolute;top:40%;left:-300px;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(192,24,58,.05) 0%,transparent 70%);
  pointer-events:none;
}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem;perspective:1200px}
.tcard{
  background:var(--card);border:1px solid rgba(255,255,255,.06);
  border-radius:20px;padding:2.2rem;
  position:relative;overflow:hidden;
  transition:all .5s var(--ease);
  box-shadow:0 8px 40px rgba(0,0,0,.4);
}
.tcard:nth-child(odd){transform:rotateX(1deg) translateY(-6px)}
.tcard:nth-child(even){transform:rotateX(-1deg) translateY(6px)}
.tcard:hover{transform:rotateX(0) translateY(-12px) scale(1.02) !important;border-color:rgba(212,160,23,.2);box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 40px rgba(212,160,23,.08)}
.tcard-quote-mark{
  font-family:var(--serif);font-size:5rem;font-weight:900;
  color:rgba(212,160,23,.08);line-height:1;position:absolute;top:.5rem;right:1.5rem;
}
.tcard-stars{color:var(--gold);font-size:.85rem;letter-spacing:.1em;margin-bottom:.9rem}
.tcard-text{
  font-family:var(--serif);font-size:1rem;font-style:italic;
  color:rgba(232,223,200,.75);line-height:1.85;
  margin-bottom:1.5rem;
}
.tcard-author{display:flex;align-items:center;gap:.9rem}
.tcard-av{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--deep),var(--crimson));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1.1rem;font-weight:700;color:#fff;
  box-shadow:0 4px 16px rgba(0,0,0,.3);
  border:2px solid rgba(255,255,255,.1);
}
.tcard-n{font-family:var(--sans);font-size:.85rem;font-weight:700;color:var(--cream)}
.tcard-r{font-family:var(--sans);font-size:.68rem;color:var(--muted);margin-top:.12rem}

/* Ratings row */
.ratings-row{
  display:flex;gap:1.5rem;justify-content:center;
  margin-bottom:3.5rem;flex-wrap:wrap;
}
.rating-pill{
  background:var(--card);border:1px solid var(--border);
  border-radius:100px;padding:.8rem 2rem;
  display:flex;align-items:center;gap:.8rem;
  transition:all .4s var(--spring);
  box-shadow:0 4px 24px rgba(0,0,0,.3);
}
.rating-pill:hover{transform:translateY(-4px) scale(1.04);box-shadow:0 12px 40px rgba(0,0,0,.4),0 0 20px rgba(212,160,23,.1)}
.rp-num{font-family:var(--serif);font-size:1.8rem;font-weight:900;color:var(--gold2);line-height:1;letter-spacing:-.03em}
.rp-info p:first-child{font-family:var(--sans);font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.rp-info p:last-child{color:var(--gold);font-size:.82rem;letter-spacing:.05em}

/* ════════════════════════════════════════
   GALLERY TEASER — 3D MOSAIC
════════════════════════════════════════ */
.gallery-sec{background:var(--surface);overflow:hidden;position:relative}
.g-mosaic{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:260px 260px;
  gap:.75rem;margin-top:3.5rem;
  perspective:1200px;
}
.g-cell{
  border-radius:14px;overflow:hidden;cursor:pointer;
  position:relative;
  transition:all .5s var(--ease);
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.g-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease);filter:brightness(.85) saturate(1.1)}
.g-cell:hover{transform:scale(1.03) translateY(-6px) rotateX(2deg);box-shadow:0 24px 60px rgba(0,0,0,.6),0 0 0 2px rgba(212,160,23,.3);z-index:2}
.g-cell:hover img{transform:scale(1.08)}
.g-cell:nth-child(1){grid-column:span 2;grid-row:span 2}
.g-cell:nth-child(4){grid-column:span 2}
.g-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,5,15,.95) 0%,transparent 55%);
  opacity:0;transition:opacity .4s;
  display:flex;align-items:flex-end;padding:1.2rem;
}
.g-cell:hover .g-ov{opacity:1}
.g-ov span{
  font-family:var(--sans);font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:#fff;
}

/* ════════════════════════════════════════
   CTA BANNER — DRAMATIC
════════════════════════════════════════ */
.cta-sec{
  position:relative;overflow:hidden;text-align:center;
  padding:8rem 0;
  background:var(--bg);
}
.cta-sec::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:800px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,160,23,.08) 0%,rgba(192,24,58,.04) 40%,transparent 70%);
}
.cta-sec::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.cta-sec h2{
  font-family:var(--serif);font-size:clamp(2.5rem,5vw,4.5rem);
  font-weight:900;color:#fff;line-height:1;letter-spacing:-.03em;
  margin-bottom:1.2rem;position:relative;
}
.cta-sec h2 em{color:var(--gold2);font-style:italic;text-shadow:0 0 40px rgba(245,200,66,.3)}
.cta-sec p{font-family:var(--sans);font-size:1rem;color:var(--muted);margin-bottom:3rem;position:relative}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative}

/* ════════════════════════════════════════
   INNER PAGE HERO / BANNER
════════════════════════════════════════ */
.pg-banner{
  min-height:44vh;display:flex;align-items:flex-end;
  position:relative;overflow:hidden;padding-top:88px;
  background:var(--bg);
}
.pgb-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1518834107812-67b0b7c58434?w=1600&q=80') center/cover no-repeat;
  opacity:.12;transition:transform 8s ease;
}
.pg-banner:hover .pgb-bg{transform:scale(1.03)}
.pgb-ov{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,5,15,.6) 0%,rgba(8,5,15,1) 100%);
}
/* Horizontal scan line */
.pgb-scan{
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,160,23,.5),transparent);
  animation:scan-line 4s ease-in-out infinite;
}
@keyframes scan-line{0%{top:0}100%{top:100%}}
.pgb-content{position:relative;z-index:2;padding:3rem 0 3.5rem;width:100%}
.pgb-eye{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.pgb-content h1{
  font-family:var(--serif);font-size:clamp(2.5rem,5vw,4rem);
  font-weight:900;color:#fff;line-height:1;letter-spacing:-.03em;
}
.pgb-content h1 em{color:var(--gold2);font-style:italic}
.pgb-bread{
  font-family:var(--sans);font-size:.72rem;color:rgba(255,255,255,.3);margin-top:.6rem;
}
.pgb-bread a{color:var(--gold);transition:color .2s}
.pgb-bread a:hover{color:var(--gold2)}

/* ════════════════════════════════════════
   CLASSES PAGE
════════════════════════════════════════ */
.cl-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));
  gap:1.5rem;margin-top:3.5rem;
  perspective:1000px;
}
.cl-card{
  background:var(--card);border:1px solid rgba(255,255,255,.06);
  border-radius:20px;overflow:hidden;
  transition:all .5s var(--ease);cursor:default;
  box-shadow:0 8px 40px rgba(0,0,0,.4);
  transform-style:preserve-3d;
}
.cl-card:hover{
  transform:translateY(-10px) rotateX(2deg);
  border-color:rgba(212,160,23,.2);
  box-shadow:0 28px 80px rgba(0,0,0,.5),0 0 40px rgba(212,160,23,.08);
}
.cl-head{
  background:linear-gradient(140deg,var(--deep) 0%,var(--card) 100%);
  padding:2.5rem 2.2rem 2rem;text-align:center;position:relative;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.cl-head.warm{background:linear-gradient(140deg,rgba(212,160,23,.15),rgba(232,76,43,.1),var(--card))}
.cl-badge{
  position:absolute;top:1rem;right:1rem;
  background:linear-gradient(135deg,var(--gold),var(--ember));
  color:#fff;padding:.2rem .75rem;border-radius:100px;
  font-family:var(--sans);font-size:.58rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;
  box-shadow:0 3px 12px rgba(212,160,23,.4);
}
.cl-icon{font-size:2.8rem;margin-bottom:.8rem;filter:drop-shadow(0 4px 16px rgba(212,160,23,.4))}
.cl-head h3{
  font-family:var(--serif);font-size:1.6rem;font-weight:700;
  color:var(--cream);margin-bottom:.25rem;letter-spacing:-.02em;
}
.cl-head p{font-family:var(--sans);font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cl-body{padding:1.8rem 2rem}
.cl-body p{font-family:var(--sans);font-size:.87rem;color:var(--muted);line-height:1.8;margin-bottom:1.3rem;font-weight:300}
.cl-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem}
.cl-tag{
  font-family:var(--sans);font-size:.68rem;font-weight:600;
  padding:.3rem .75rem;border-radius:100px;
  background:rgba(255,255,255,.05);color:rgba(232,223,200,.6);
  border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:.3rem;
}
.lv-row{display:flex;align-items:center;gap:.4rem;margin-bottom:1.3rem}
.lv-lbl{font-family:var(--sans);font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-right:.3rem}
.lv-dot{width:8px;height:8px;border-radius:50%}
.lv-dot.on{background:var(--gold);box-shadow:0 0 8px var(--gold)}
.lv-dot.off{background:rgba(255,255,255,.12)}
.enroll{
  display:block;width:100%;text-align:center;
  font-family:var(--sans);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(255,255,255,.05);color:var(--cream);
  border:1px solid rgba(255,255,255,.1);border-radius:100px;
  padding:.85rem;cursor:pointer;transition:all .35s var(--ease);
}
.enroll:hover{background:linear-gradient(135deg,var(--gold),var(--ember));border-color:transparent;color:#fff;box-shadow:0 6px 24px rgba(212,160,23,.4);transform:translateY(-2px)}

/* ════════════════════════════════════════
   GALLERY PAGE
════════════════════════════════════════ */
.gal-masonry{columns:3;column-gap:1rem;margin-top:3rem}
.gal-item{break-inside:avoid;margin-bottom:1rem;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;box-shadow:0 4px 24px rgba(0,0,0,.4);transition:all .5s var(--ease)}
.gal-item img{width:100%;display:block;transition:transform .7s var(--ease);filter:brightness(.85)}
.gal-item:hover{transform:scale(1.02) translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 0 2px rgba(212,160,23,.3);z-index:2}
.gal-item:hover img{transform:scale(1.07);filter:brightness(1)}
.gal-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,5,15,.95),transparent 55%);opacity:0;transition:opacity .4s;display:flex;align-items:flex-end;padding:1rem}
.gal-item:hover .gal-ov{opacity:1}
.gal-ov span{font-family:var(--sans);font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#fff}
/* Lightbox */
#lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.97);z-index:9999;align-items:center;justify-content:center}
#lb.show{display:flex}
#lb-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:0 40px 120px rgba(0,0,0,.8)}
.lb-x{position:absolute;top:1.5rem;right:2rem;background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;opacity:.6;transition:opacity .2s;z-index:10}
.lb-x:hover{opacity:1}

/* ════════════════════════════════════════
   SCHEDULE
════════════════════════════════════════ */
.sch-wrap{overflow-x:auto;margin-top:3rem;border-radius:16px;overflow:hidden;box-shadow:0 8px 60px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.06)}
.sch-t{width:100%;border-collapse:collapse}
.sch-t thead th{
  background:rgba(212,160,23,.12);
  color:var(--gold2);
  font-family:var(--sans);font-size:.65rem;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;
  padding:1rem 1.2rem;text-align:center;border-bottom:1px solid rgba(212,160,23,.2);
}
.sch-t tbody td{
  padding:.9rem 1rem;text-align:center;
  background:var(--card);border-bottom:1px solid rgba(255,255,255,.04);
  font-size:.82rem;transition:background .2s;
}
.sch-t tbody tr:hover td{background:rgba(255,255,255,.04)}
.sch-t tbody tr:last-child td{border-bottom:none}
.ttime{color:var(--gold);font-weight:800;font-family:var(--sans);white-space:nowrap}
.slot{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.3rem .8rem;border-radius:100px;
  font-size:.7rem;font-weight:700;font-family:var(--sans);min-width:110px;
  border:1px solid rgba(255,255,255,.06);
}
.s-bol{background:rgba(232,76,43,.15);color:#F08060;border-color:rgba(232,76,43,.2)}
.s-hip{background:rgba(92,31,160,.2);color:#B07AE0;border-color:rgba(92,31,160,.25)}
.s-con{background:rgba(0,140,180,.15);color:#60C8E0;border-color:rgba(0,140,180,.2)}
.s-kat{background:rgba(212,160,23,.15);color:var(--gold2);border-color:rgba(212,160,23,.2)}
.s-jaz{background:rgba(180,0,120,.15);color:#E070C0;border-color:rgba(180,0,120,.2)}
.s-fit{background:rgba(0,180,80,.12);color:#60E090;border-color:rgba(0,180,80,.18)}
.s-wed{background:rgba(192,24,58,.15);color:#E07090;border-color:rgba(192,24,58,.2)}
.sch-legend{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.5rem;padding:1.1rem 1.5rem;background:var(--card);border-radius:12px;border:1px solid rgba(255,255,255,.05)}
.leg-i{display:flex;align-items:center;gap:.4rem;font-family:var(--sans);font-size:.7rem;font-weight:600;color:var(--muted)}
.leg-dot{width:9px;height:9px;border-radius:50%}

/* ════════════════════════════════════════
   CONTACT
════════════════════════════════════════ */
.con-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:5rem;align-items:start;margin-top:3.5rem}
.ci-row{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-start}
.ci-icon{
  width:46px;height:46px;min-width:46px;border-radius:12px;
  background:rgba(212,160,23,.08);border:1px solid rgba(212,160,23,.18);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  transition:all .35s;
}
.ci-row:hover .ci-icon{background:rgba(212,160,23,.15);transform:scale(1.1) rotate(-5deg)}
.ci-lbl{font-family:var(--sans);font-size:.6rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem}
.ci-val{font-family:var(--sans);font-size:.9rem;color:var(--cream)}
.ci-val a{color:var(--cream);transition:color .2s}.ci-val a:hover{color:var(--gold2)}
.wa-cta{
  display:inline-flex;align-items:center;gap:.75rem;
  background:#25D366;color:#fff;padding:.9rem 1.8rem;border-radius:100px;
  font-family:var(--sans);font-size:.8rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;margin-top:1.5rem;
  transition:all .4s var(--spring);
  box-shadow:0 4px 20px rgba(37,211,102,.3);
}
.wa-cta:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 10px 40px rgba(37,211,102,.5)}
.map-box{margin-top:2rem;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.07);box-shadow:0 8px 40px rgba(0,0,0,.4)}
.map-box iframe{width:100%;height:260px;border:none;display:block;filter:invert(92%) hue-rotate(180deg)}
.cf-box{
  background:var(--card);border:1px solid rgba(255,255,255,.07);
  border-radius:20px;padding:3rem;
  box-shadow:0 20px 80px rgba(0,0,0,.5);
}
.cf-head{display:flex;align-items:center;gap:.9rem;margin-bottom:.5rem}
.cf-head img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);box-shadow:0 0 16px rgba(212,160,23,.3)}
.cf-head h3{font-family:var(--serif);font-size:1.8rem;font-weight:700;color:var(--cream);letter-spacing:-.02em}
.cf-box > p{font-family:var(--sans);font-size:.85rem;color:var(--muted);margin-bottom:2rem;line-height:1.65}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1rem}
.fg label{display:block;font-family:var(--sans);font-size:.6rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.42rem}
.fg input,.fg select,.fg textarea{
  width:100%;padding:.85rem 1.1rem;
  background:rgba(255,255,255,.04);
  border:1.5px solid rgba(255,255,255,.08);
  border-radius:10px;
  font-family:var(--sans);font-size:.9rem;color:var(--cream);
  outline:none;transition:all .3s;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:rgba(212,160,23,.5);
  background:rgba(255,255,255,.07);
  box-shadow:0 0 0 3px rgba(212,160,23,.1);
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--muted)}
.fg select option{background:var(--card);color:var(--cream)}
.fg textarea{resize:vertical;min-height:110px}
.f-submit{
  width:100%;background:linear-gradient(135deg,var(--gold) 0%,var(--ember) 100%);
  color:#fff;border:none;border-radius:100px;padding:1rem;cursor:pointer;
  font-family:var(--sans);font-size:.85rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  transition:all .4s var(--spring);
  box-shadow:0 6px 24px rgba(212,160,23,.35);
}
.f-submit:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 14px 48px rgba(212,160,23,.55)}

/* ════════════════════════════════════════
   ABOUT PAGE EXTRAS
════════════════════════════════════════ */
.mv-strip{background:var(--surface);padding:5rem 0}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem;perspective:800px}
.mv-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:20px;padding:2.8rem;
  transition:all .5s var(--ease);
  box-shadow:0 8px 40px rgba(0,0,0,.4);
}
.mv-card:nth-child(1){transform:rotateX(2deg) rotateY(-1deg)}
.mv-card:nth-child(2){transform:rotateX(2deg) rotateY(1deg)}
.mv-card:hover{transform:translateY(-8px) rotateX(0) rotateY(0);border-color:rgba(212,160,23,.25);box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 30px rgba(212,160,23,.07)}
.mv-card h3{font-family:var(--serif);font-size:1.9rem;font-weight:700;color:var(--gold2);margin-bottom:.9rem;letter-spacing:-.02em}
.mv-card p{font-family:var(--sans);color:var(--muted);line-height:1.85;font-size:.93rem;font-weight:300}

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
footer{
  background:var(--surface);border-top:1px solid rgba(255,255,255,.05);
  padding:5rem 0 0;
}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;margin-bottom:4rem}
.ft-brand p{font-family:var(--sans);font-size:.84rem;color:var(--muted);line-height:1.85;max-width:280px;font-weight:300;margin-top:1rem}
footer h5{font-family:var(--sans);font-size:.6rem;font-weight:800;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem}
footer ul{list-style:none}
footer li{margin-bottom:.65rem}
footer li a{font-family:var(--sans);font-size:.83rem;color:var(--muted);transition:color .2s}
footer li a:hover{color:var(--gold2)}
.ft-ci{display:flex;gap:.75rem;margin-bottom:.9rem;align-items:flex-start}
.ft-ci span:first-child{color:var(--gold);font-size:.9rem;margin-top:.05rem}
.ft-ci span:last-child{font-family:var(--sans);font-size:.82rem;color:var(--muted);line-height:1.6}
.ft-soc{display:flex;gap:.6rem;margin-top:1.8rem}
.fsc{
  width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:.68rem;font-weight:800;color:var(--muted);
  transition:all .35s var(--spring);
}
.fsc:hover{background:var(--gold);border-color:var(--gold);color:var(--bg);transform:translateY(-3px) scale(1.1)}
.ft-bot{
  border-top:1px solid rgba(255,255,255,.05);
  padding:1.5rem 0;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:.8rem;
}
.ft-bot p{font-family:var(--sans);font-size:.73rem;color:rgba(255,255,255,.2)}
.ft-bot a{color:var(--gold)}

/* WhatsApp float */
.wa-fl{position:fixed;bottom:5.5rem;right:1.5rem;z-index:950}
.wa-fl a{
  width:54px;height:54px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;
  box-shadow:0 4px 24px rgba(37,211,102,.5);transition:all .4s var(--spring);
}
.wa-fl a:hover{transform:scale(1.15) translateY(-4px);box-shadow:0 12px 40px rgba(37,211,102,.65)}

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr;min-height:auto;padding:3rem 0 5rem}
  .hero-visual{display:none}
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .founder-grid{grid-template-columns:1fr}
  .founder-photo-col img{min-height:400px}
  .founder-photo-col::after{display:none}
  .ft-grid{grid-template-columns:1fr 1fr}
  .s-grid{grid-template-columns:repeat(2,1fr)}
  .con-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  #qnav{display:flex}
  .wa-fl{bottom:5.5rem}
  body{padding-bottom:68px}
  section{padding:5rem 0}
  .s-grid{grid-template-columns:1fr}
  .gal-masonry{columns:1}
  .testi-grid{grid-template-columns:1fr}
  .g-mosaic{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .g-cell:nth-child(1){grid-column:span 2;grid-row:auto}
  .g-cell:nth-child(4){grid-column:span 1}
  .ft-grid{grid-template-columns:1fr}
  .mv-grid{grid-template-columns:1fr}
  .hero-h1{font-size:clamp(2.5rem,8vw,4rem)}
  .wrap{padding:0 1.4rem}
  .tcard:nth-child(odd),.tcard:nth-child(even){transform:none}
}
@media(max-width:480px){
  .hero-stats{flex-direction:column}
  .hstat{border-right:none;border-bottom:1px solid var(--border)}
  .hstat:last-child{border-bottom:none}
  .ratings-row{flex-direction:column;align-items:center}
}
