/* =============================================================
   S.S ENTERPRISES — Immersive Real Estate Universe
   Design system & global styles
   Brand: Inter | Red #B80101 | Black #100F0F | White/Grey
   ============================================================= */

/* ---------- Design tokens ---------- */
:root{
  /* Brand */
  --red:        #b80101;
  --red-bright: #ff1f1f;
  --red-soft:   #e23a3a;
  --red-deep:   #7a0000;
  --ink:        #100f0f;   /* brand black */
  --void:       #08080a;   /* deepest bg */
  --space:      #0d0d10;   /* primary bg */
  --space-2:    #14141a;   /* raised bg */
  --grey-900:   #1a1a20;
  --grey-700:   #2a2a33;
  --grey-500:   #585866;
  --grey-300:   #9a9aa8;
  --grey-100:   #d7d7e0;
  --white:      #f6f6f9;
  --pure:       #ffffff;

  /* Functional */
  --bg:          var(--space);
  --fg:          var(--white);
  --muted:       var(--grey-300);
  --line:        rgba(255,255,255,.10);
  --line-strong: rgba(255,255,255,.18);
  --glass:       rgba(14,14,20,.78);
  --glass-2:     rgba(255,255,255,.04);

  /* Glow */
  --glow-red:   0 0 40px rgba(184,1,1,.45);
  --glow-soft:  0 0 80px rgba(184,1,1,.18);

  /* Type */
  --font: "Inter", "Inter Tight", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --fs-mega:  clamp(3.2rem, 13vw, 13rem);
  --fs-h1:    clamp(2.6rem, 8vw, 7.5rem);
  --fs-h2:    clamp(2rem, 5.2vw, 4.6rem);
  --fs-h3:    clamp(1.4rem, 2.6vw, 2.4rem);
  --fs-lead:  clamp(1.05rem, 1.6vw, 1.45rem);
  --fs-body:  clamp(1rem, 1.1vw, 1.12rem);
  --fs-small: .86rem;

  /* Layout */
  --maxw: 1320px;
  --gut:  clamp(1.2rem, 5vw, 6rem);
  --radius: 18px;
  --radius-lg: 28px;

  /* Motion */
  --ease: cubic-bezier(.16,1,.3,1);
  --ease-soft: cubic-bezier(.45,0,.1,1);
  --dur: .9s;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:auto; }
body{
  font-family:var(--font);
  font-size:var(--fs-body);
  line-height:1.6;
  color:var(--fg);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.is-locked{ overflow:hidden; height:100vh; }
img,video,canvas{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:0; background:none; color:inherit; }
ul{ list-style:none; }
::selection{ background:var(--red); color:#fff; }

/* Scrollbar */
::-webkit-scrollbar{ width:10px; }
::-webkit-scrollbar-track{ background:var(--void); }
::-webkit-scrollbar-thumb{ background:linear-gradient(var(--red),var(--red-deep)); border-radius:10px; }

/* ---------- Background scene canvas ---------- */
#bg-canvas{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:0;
  pointer-events:none;
}
.scene-veil{                 /* gradient atmosphere over the 3D scene */
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(184,1,1,.10), transparent 55%),
    radial-gradient(100% 60% at 50% 110%, rgba(184,1,1,.08), transparent 60%),
    linear-gradient(180deg, rgba(8,8,10,.20), rgba(8,8,10,.55));
}
.grain{                      /* subtle film grain */
  position:fixed; inset:0; z-index:2; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- Layout primitives ---------- */
main{ position:relative; z-index:3; }
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
section{ position:relative; padding-block:clamp(5rem,12vh,11rem); }
.section-tag{
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.78rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--red-soft); font-weight:600; margin-bottom:1.4rem;
}
.section-tag::before{ content:""; width:34px; height:1px; background:var(--red); display:inline-block; }
.eyebrow{ color:var(--muted); }

/* ---------- Typography helpers ---------- */
h1,h2,h3{ font-weight:800; line-height:.98; letter-spacing:-.02em; }
.display{ font-size:var(--fs-h1); font-weight:900; line-height:.92; letter-spacing:-.035em; }
.mega{ font-size:var(--fs-mega); font-weight:900; line-height:.84; letter-spacing:-.045em; text-transform:uppercase; }
.h2{ font-size:var(--fs-h2); }
.lead{ font-size:var(--fs-lead); color:var(--grey-100); max-width:60ch; }
.outline-text{
  -webkit-text-stroke:1.5px rgba(255,255,255,.34);
  color:transparent;
}
.text-red{ color:var(--red-soft); }
.text-gradient{
  background:linear-gradient(120deg, #fff 10%, var(--red-bright) 55%, var(--red-deep) 95%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Split-line reveal */
.reveal-line{ display:block; overflow:hidden; }
.reveal-line > span{ display:block; will-change:transform; }

/* legibility over the live 3D landscape */
h1,h2,.display,.mega,.h2{ text-shadow:0 2px 34px rgba(8,8,10,.55); }
.lead,.hero-sub,.about-copy p,.sec-head p,.ceo-quote,.section-tag{ text-shadow:0 1px 22px rgba(8,8,10,.6); }

/* ---------- Buttons ---------- */
.btn{
  position:relative; display:inline-flex; align-items:center; gap:.7rem;
  padding:1rem 1.7rem; border-radius:100px;
  font-weight:600; font-size:.95rem; letter-spacing:.01em;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .4s;
  overflow:hidden; isolation:isolate;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--red); color:#fff; box-shadow:var(--glow-red); }
.btn-primary::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(120deg,var(--red-bright),var(--red-deep));
  opacity:0; transition:opacity .4s;
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 12px 50px rgba(184,1,1,.6); }
.btn-primary:hover::after{ opacity:1; }
.btn-ghost{ border:1px solid var(--line-strong); color:var(--white); background:rgba(255,255,255,.02); backdrop-filter:blur(6px); }
.btn-ghost:hover{ border-color:var(--red); background:rgba(184,1,1,.10); transform:translateY(-3px); }
.btn-whatsapp{ background:#1faf54; color:#fff; }
.btn-whatsapp:hover{ transform:translateY(-3px); box-shadow:0 12px 40px rgba(31,175,84,.45); }
.btn-lg{ padding:1.15rem 2.1rem; font-size:1rem; }

.link-arrow{
  display:inline-flex; align-items:center; gap:.5rem; font-weight:600; color:var(--white);
  border-bottom:1px solid var(--line-strong); padding-bottom:.25rem; transition:.35s var(--ease);
}
.link-arrow:hover{ color:var(--red-soft); gap:.85rem; border-color:var(--red); }

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--gut);
  transition:padding .4s var(--ease), background .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,8,10,.72); backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line); padding-block:.7rem;
}
.brand{ display:flex; align-items:center; gap:.7rem; z-index:60; }
.brand .logo-mark{ width:auto; height:44px; display:block; }
.brand .brand-name{ font-weight:800; letter-spacing:-.01em; font-size:1.05rem; line-height:1; }
.brand .brand-name small{ display:block; font-weight:500; font-size:.54rem; letter-spacing:.06em; color:var(--muted); margin-top:3px; text-transform:none; }
.nav .brand .brand-name small{ white-space:nowrap; }
@media (max-width:760px){ .nav .brand .brand-name small{ display:none; } }
.nav-links{ display:flex; align-items:center; gap:2.1rem; }
.nav-links a{ font-size:.92rem; font-weight:500; color:var(--grey-100); position:relative; transition:color .3s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--red); transition:width .35s var(--ease); }
.nav-links a:hover{ color:#fff; } .nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.nav-toggle{ display:none; width:44px; height:44px; border-radius:50%; border:1px solid var(--line-strong); flex-direction:column; gap:5px; align-items:center; justify-content:center; z-index:60; }
.nav-toggle span{ width:18px; height:2px; background:#fff; transition:.35s var(--ease); }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.mobile-menu{
  position:fixed; inset:0; z-index:55; background:rgba(8,8,10,.97); backdrop-filter:blur(10px);
  display:flex; flex-direction:column; justify-content:center; gap:1.4rem; padding:var(--gut);
  transform:translateY(-100%); transition:transform .6s var(--ease), visibility .6s;
  pointer-events:none; visibility:hidden;   /* keep closed links out of the tab order */
}
.mobile-menu.open{ transform:translateY(0); pointer-events:auto; visibility:visible; }
.mobile-menu a{ font-size:clamp(1.8rem,7vw,3rem); font-weight:800; letter-spacing:-.02em; }
.mobile-menu a span{ color:var(--red); font-size:1rem; vertical-align:super; margin-right:.5rem; }

/* ============================================================
   PROGRESS / LOADER
   ============================================================ */
.loader{
  position:fixed; inset:0; z-index:200; background:var(--void);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2rem;
  transition:opacity .8s var(--ease), visibility .8s;
}
.loader.done{ opacity:0; visibility:hidden; }
.loader .loader-mark{ width:auto; height:104px; animation:pulse 1.8s var(--ease) infinite; }
@keyframes pulse{ 0%,100%{ transform:scale(1); opacity:.9 } 50%{ transform:scale(1.08); opacity:1 } }
.loader-bar{ width:min(260px,60vw); height:2px; background:var(--grey-700); overflow:hidden; border-radius:2px; }
.loader-bar i{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--red),var(--red-bright)); }
.loader-pct{ font-size:.8rem; letter-spacing:.3em; color:var(--muted); }

.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:60; background:linear-gradient(90deg,var(--red),var(--red-bright)); box-shadow:0 0 12px var(--red); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ min-height:100svh; display:flex; flex-direction:column; justify-content:center; padding-top:8rem; padding-bottom:4rem; }
.hero-inner{ max-width:1100px; }
.hero-kicker{
  display:inline-flex; align-items:center; gap:.7rem; padding:.5rem 1rem; border:1px solid var(--line-strong);
  border-radius:100px; font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--grey-100);
  margin-bottom:2rem; background:var(--glass); backdrop-filter:blur(8px);
}
.hero-kicker .dot{ width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:var(--glow-red); animation:blink 2s infinite; }
@keyframes blink{ 50%{ opacity:.3 } }
.hero h1{ font-size:var(--fs-mega); font-weight:900; line-height:.86; text-transform:uppercase; letter-spacing:-.04em; margin-bottom:1.8rem; }
.hero h1 .ln2{ color:transparent; -webkit-text-stroke:1.5px rgba(255,255,255,.55); }
.hero h1 em{ font-style:normal; color:var(--red); }
.hero-tagline{ font-size:clamp(1.05rem,1.8vw,1.45rem); font-weight:700; letter-spacing:.01em; color:var(--red-soft); margin-bottom:1rem; text-shadow:0 1px 20px rgba(8,8,10,.7); }
.hero-sub{ font-size:var(--fs-lead); color:var(--grey-100); max-width:54ch; margin-bottom:2.6rem; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.hero-scroll{ position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.6rem; color:var(--muted); font-size:.72rem; letter-spacing:.3em; text-transform:uppercase; }
.hero-scroll .mouse{ width:22px; height:36px; border:1.5px solid var(--line-strong); border-radius:14px; position:relative; }
.hero-scroll .mouse::after{ content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%); width:3px; height:7px; background:var(--red); border-radius:2px; animation:scrolldot 1.6s infinite; }
@keyframes scrolldot{ 0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1} 100%{opacity:0;transform:translate(-50%,12px)} }

/* Marquee strip */
.marquee{ border-block:1px solid var(--line); padding-block:1.1rem; overflow:hidden; white-space:nowrap; position:relative; z-index:3; background:rgba(8,8,10,.4); }
.marquee-track{ display:inline-flex; gap:3rem; animation:scrollx 28s linear infinite; }
.marquee span{ font-size:clamp(1.1rem,2.4vw,2rem); font-weight:800; text-transform:uppercase; letter-spacing:.01em; color:var(--grey-100); display:inline-flex; align-items:center; gap:3rem; }
.marquee span b{ color:var(--red); }
@keyframes scrollx{ to{ transform:translateX(-50%) } }

/* ============================================================
   STATS
   ============================================================ */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.stat{ background:var(--space); padding:2.4rem 1.8rem; transition:background .4s; }
.stat:hover{ background:var(--space-2); }
.stat .num{ font-size:clamp(2.4rem,5vw,4rem); font-weight:900; letter-spacing:-.03em; line-height:1; color:#fff; }
.stat .num span{ color:var(--red); }
.stat .label{ margin-top:.7rem; color:var(--muted); font-size:.9rem; }

/* ============================================================
   GENERIC SECTION HEADERS
   ============================================================ */
.sec-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:2rem; margin-bottom:3.5rem; }
.sec-head .h2{ max-width:18ch; }
.sec-head p{ max-width:42ch; color:var(--muted); }

/* ============================================================
   ABOUT / STORY
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.about-copy p{ color:var(--grey-100); margin-bottom:1.3rem; }
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-top:2.2rem; }
.pillar{ border:1px solid var(--line); border-radius:var(--radius); padding:1.4rem; background:rgba(12,12,17,.7); transition:.4s var(--ease); }
.pillar:hover{ border-color:var(--red); transform:translateY(-4px); }
.pillar .pn{ color:var(--red); font-weight:800; font-size:1.1rem; }
.pillar h4{ margin:.6rem 0 .3rem; font-size:1.05rem; }
.pillar p{ color:var(--muted); font-size:.9rem; }
.about-visual{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:3/4; border:1px solid var(--line); }
.about-visual img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.about-visual:hover img{ transform:scale(1.06); }
.about-visual .badge{ position:absolute; left:1.2rem; bottom:1.2rem; background:var(--glass); backdrop-filter:blur(10px); border:1px solid var(--line-strong); border-radius:14px; padding:1rem 1.2rem; }
.about-visual .badge b{ display:block; font-size:1.8rem; font-weight:900; color:#fff; }
.about-visual .badge span{ color:var(--muted); font-size:.8rem; }

/* ============================================================
   CEO MESSAGE
   ============================================================ */
.ceo{ position:relative; }
.ceo-card{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(2rem,5vw,4.5rem); align-items:center;
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.6rem,4vw,3.5rem);
  background:linear-gradient(135deg, rgba(120,10,10,.55), rgba(12,12,18,.9)); backdrop-filter:blur(10px); }
.ceo-portrait{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5; border:1px solid var(--line-strong); }
.ceo-portrait img{ width:100%; height:100%; object-fit:cover; object-position:top center; }
.ceo-quote{ font-size:clamp(1.25rem,2.4vw,2rem); line-height:1.4; font-weight:600; letter-spacing:-.01em; color:#fff; }
.ceo-quote .mark{ color:var(--red); font-size:3rem; line-height:0; vertical-align:-.4em; font-weight:900; }
.ceo-sign{ margin-top:1.8rem; display:flex; align-items:center; gap:1rem; }
.ceo-sign .l{ width:40px; height:1px; background:var(--red); }
.ceo-sign b{ font-weight:800; } .ceo-sign span{ color:var(--muted); font-size:.9rem; }

/* ============================================================
   SERVICES
   ============================================================ */
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.service{
  position:relative; border:1px solid var(--line-strong); border-radius:var(--radius-lg); padding:2.2rem 2rem;
  background:linear-gradient(180deg, rgba(22,22,29,.97) 0%, rgba(11,11,16,.985) 100%); overflow:hidden; transition:.5s var(--ease); min-height:280px;
  display:flex; flex-direction:column; justify-content:space-between;
  box-shadow:0 22px 48px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.05);
}
.service::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 80% at 0% 0%, rgba(184,1,1,.16), transparent 60%); opacity:0; transition:opacity .5s; }
.service:hover{ border-color:var(--red); transform:translateY(-6px); box-shadow:0 34px 70px rgba(0,0,0,.55), 0 0 24px rgba(184,1,1,.18); }
.service:hover::before{ opacity:1; }
.service .ico{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; background:rgba(184,1,1,.12); border:1px solid rgba(184,1,1,.3); color:var(--red-soft); margin-bottom:1.4rem; }
.service .ico svg{ width:26px; height:26px; }
.service h3{ font-size:1.35rem; margin-bottom:.6rem; }
.service p{ color:var(--muted); font-size:.95rem; }
.service .idx{ position:absolute; top:1.4rem; right:1.6rem; font-size:.8rem; color:var(--grey-300); font-weight:700; letter-spacing:.1em; }

/* ============================================================
   PROJECTS (horizontal showcase)
   ============================================================ */
.showcase{ overflow:hidden; }
.showcase-track{
  display:flex; gap:1.6rem; padding-inline:var(--gut); padding-bottom:1.2rem;
  overflow-x:auto; overflow-y:hidden; scroll-snap-type:x proximity; scroll-padding-left:var(--gut);
  cursor:grab; scrollbar-width:none; -ms-overflow-style:none;
}
.showcase-track::-webkit-scrollbar{ height:0; display:none; }
.showcase-track.dragging{ cursor:grabbing; scroll-snap-type:none; user-select:none; }
.proj-card{
  position:relative; flex:0 0 min(78vw,560px); height:min(70vh,640px); border-radius:var(--radius-lg);
  overflow:hidden; border:1px solid var(--line); background:var(--space-2); scroll-snap-align:start;
}
.proj-card img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.proj-card:hover img{ transform:scale(1.07); }
.proj-card .pc-overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,8,10,0) 35%, rgba(8,8,10,.92)); display:flex; flex-direction:column; justify-content:flex-end; padding:2rem; }
.proj-card .tagpill{ align-self:flex-start; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; padding:.4rem .8rem; border-radius:100px; border:1px solid var(--line-strong); background:var(--glass); margin-bottom:1rem; }
.proj-card .tagpill.ready{ color:#5fe39a; border-color:rgba(95,227,154,.4); }
.proj-card .tagpill.install{ color:var(--red-soft); border-color:rgba(226,58,58,.4); }
.proj-card h3{ font-size:1.9rem; margin-bottom:.4rem; }
.proj-card p{ color:var(--grey-100); font-size:.92rem; margin-bottom:1.2rem; }
.showcase-hint{ display:flex; align-items:center; gap:.6rem; color:var(--muted); font-size:.82rem; letter-spacing:.15em; text-transform:uppercase; margin-top:1.4rem; }

/* Standard project grid (projects.html) */
.proj-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; }
.proj-tile{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:16/11; }
.proj-tile img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.proj-tile:hover img{ transform:scale(1.06); }
.proj-tile .pt-info{ position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(8,8,10,.9)); padding:1.8rem; display:flex; flex-direction:column; justify-content:flex-end; }
.proj-tile h3{ font-size:1.5rem; }
.proj-tile p{ color:var(--grey-100); font-size:.88rem; margin-top:.3rem; }

/* ============================================================
   UPCOMING MEGA PROJECTS
   ============================================================ */
.mega-list{ display:grid; gap:1.4rem; }
.mega-item{
  position:relative; display:grid; grid-template-columns:1fr 1fr; gap:0; align-items:stretch;
  border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--space-2); min-height:340px;
}
.mega-item:nth-child(even){ direction:rtl; }
.mega-item:nth-child(even) > *{ direction:ltr; }
.mega-media{ position:relative; overflow:hidden; }
.mega-media img{ width:100%; height:100%; object-fit:cover; min-height:280px; transition:transform 1.2s var(--ease); }
.mega-item:hover .mega-media img{ transform:scale(1.08); }
.mega-body{ padding:clamp(1.8rem,3.5vw,3rem); display:flex; flex-direction:column; justify-content:center; }
.mega-body .status{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red-soft); margin-bottom:1rem; font-weight:600; }
.mega-body h3{ font-size:clamp(1.8rem,3.5vw,2.8rem); margin-bottom:1rem; }
.mega-body p{ color:var(--grey-100); font-size:.98rem; margin-bottom:1.5rem; }
.mega-feats{ display:flex; flex-wrap:wrap; gap:.6rem; }
.mega-feats li{ font-size:.78rem; padding:.4rem .8rem; border:1px solid var(--line); border-radius:100px; color:var(--grey-100); }

/* ============================================================
   NAYA NAZIMABAD / INVENTORY teaser
   ============================================================ */
.inv-teaser{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.blocks-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:.7rem; }
.block-chip{ aspect-ratio:1; border:1px solid var(--line); border-radius:14px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.3rem; background:rgba(12,12,17,.86); transition:.4s var(--ease); }
.block-chip:hover{ border-color:var(--red); background:rgba(184,1,1,.22); transform:translateY(-4px); }
.block-chip b{ font-size:1.6rem; font-weight:900; }
.block-chip span{ font-size:.66rem; color:var(--muted); letter-spacing:.08em; text-align:center; }

/* Featured listings (cards) */
.listing-filter{ display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:1.6rem; }
.listing-filter button{ padding:.55rem 1.1rem; border:1px solid var(--line-strong); border-radius:100px; color:var(--grey-100); font-size:.9rem; font-weight:600; background:rgba(12,12,17,.6); transition:.3s var(--ease); }
.listing-filter button.on, .listing-filter button:hover{ background:var(--red); border-color:var(--red); color:#fff; }
.listings-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.listing{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:rgba(12,12,17,.86); transition:.45s var(--ease); }
.listing:hover{ transform:translateY(-6px); border-color:var(--red); box-shadow:0 28px 60px rgba(0,0,0,.45); }
.listing .li-media{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.listing .li-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.listing:hover .li-media img{ transform:scale(1.06); }
.listing .li-type{ position:absolute; top:1rem; left:1rem; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; padding:.35rem .8rem; border-radius:100px; background:rgba(184,1,1,.9); color:#fff; }
.listing .li-status{ position:absolute; top:1rem; right:1rem; font-size:.68rem; padding:.35rem .7rem; border-radius:100px; background:rgba(8,8,10,.8); backdrop-filter:blur(4px); }
.listing .li-status.ready{ color:#5fe39a; } .listing .li-status.inst{ color:var(--red-soft); }
.listing .li-status.sold{ color:#cfcfd8; background:rgba(255,255,255,.14); }
.listing.is-sold{ opacity:.7; }
.listing.is-sold .li-media::after{ content:"SOLD"; position:absolute; inset:0; display:grid; place-items:center; font-size:1.7rem; font-weight:900; letter-spacing:.34em; color:#fff; text-shadow:0 2px 16px #000; background:rgba(8,8,10,.5); }
.listing.is-sold .li-cta .btn-primary{ display:none; }
.listing .li-body{ padding:1.3rem 1.4rem 1.5rem; display:flex; flex-direction:column; gap:.85rem; flex:1; }
.listing h3{ font-size:1.08rem; line-height:1.3; }
.listing .li-specs{ display:flex; flex-wrap:wrap; gap:.5rem; }
.listing .li-specs span{ font-size:.78rem; color:var(--grey-100); background:rgba(255,255,255,.05); border:1px solid var(--line); padding:.3rem .7rem; border-radius:8px; }
.listing .li-specs span b{ color:#fff; }
.listing .li-feats{ display:flex; flex-wrap:wrap; gap:.4rem; }
.listing .li-feats li{ font-size:.72rem; color:var(--muted); }
.listing .li-feats li::after{ content:"·"; margin-left:.4rem; color:var(--grey-500); }
.listing .li-feats li:last-child::after{ content:""; }
.listing .li-price{ margin-top:auto; border-top:1px solid var(--line); padding-top:1rem; }
.listing .li-price .demand{ font-size:1.4rem; font-weight:900; color:#fff; letter-spacing:-.02em; }
.listing .li-price .demand span{ font-size:.72rem; font-weight:500; color:var(--muted); margin-left:.4rem; letter-spacing:.05em; text-transform:uppercase; }
.listing .li-plan{ display:flex; gap:1.2rem; flex-wrap:wrap; margin-top:.6rem; font-size:.82rem; }
.listing .li-plan b{ display:block; color:#fff; } .listing .li-plan span{ color:var(--muted); font-size:.72rem; }
.listing .li-cta{ display:flex; gap:.6rem; margin-top:1rem; }
.listing .li-cta .btn{ flex:1; justify-content:center; padding:.7rem; font-size:.85rem; }
@media (max-width:1024px){ .listings-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .listings-grid{ grid-template-columns:1fr; } }

/* Inventory page table */
.inv-controls{ display:flex; flex-wrap:wrap; gap:.8rem; margin-bottom:1.6rem; align-items:center; }
.inv-controls select,.inv-controls input{
  background:var(--space-2); border:1px solid var(--line-strong); color:#fff; padding:.7rem 1rem; border-radius:10px; font-family:inherit; font-size:.9rem;
}
.inv-controls .count{ margin-left:auto; color:var(--muted); font-size:.85rem; }
/* Solid, opaque surface so the 3D background never bleeds through the data */
.inv-table-wrap{ border:1px solid var(--line-strong); border-radius:var(--radius); overflow:auto; max-height:70vh; background:#0c0c11; box-shadow:0 28px 60px rgba(0,0,0,.55); }
.inv-table-wrap:focus-visible{ outline:2px solid var(--red-bright); outline-offset:2px; }
table.inv{ width:100%; border-collapse:collapse; font-size:.88rem; min-width:680px; background:#0c0c11; }
table.inv th{ position:sticky; top:0; background:#17171f; text-align:left; padding:1rem; font-weight:600; color:#fff; letter-spacing:.04em; border-bottom:1px solid var(--line-strong); z-index:2; cursor:pointer; }
table.inv td{ padding:.9rem 1rem; border-bottom:1px solid var(--line); color:var(--grey-100); background:#0c0c11; }
table.inv tr:nth-child(even) td{ background:#101017; }
table.inv tr:hover td{ background:rgba(184,1,1,.10); color:#fff; }
.pill-status{ font-size:.72rem; padding:.25rem .6rem; border-radius:100px; }
.pill-status.available{ color:#5fe39a; background:rgba(95,227,154,.12); }
.pill-status.installments{ color:var(--red-soft); background:rgba(226,58,58,.12); }

/* ============================================================
   VIDEO GALLERY
   ============================================================ */
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.video-card{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); aspect-ratio:16/10; cursor:pointer; }
.video-card img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.video-card:hover img{ transform:scale(1.06); }
.video-card .play{ position:absolute; inset:0; display:grid; place-items:center; background:rgba(8,8,10,.35); transition:background .4s; }
.video-card:hover .play{ background:rgba(8,8,10,.15); }
.video-card .play i{ width:64px; height:64px; border-radius:50%; background:var(--red); display:grid; place-items:center; box-shadow:var(--glow-red); transition:transform .4s var(--ease); }
.video-card:hover .play i{ transform:scale(1.12); }
.video-card .play i::after{ content:""; border-left:18px solid #fff; border-top:11px solid transparent; border-bottom:11px solid transparent; margin-left:4px; }
.video-card .vc-title{ position:absolute; left:1.2rem; bottom:1.2rem; right:1.2rem; font-weight:700; font-size:1rem; text-shadow:0 2px 12px #000; }

/* ============================================================
   TEAM
   ============================================================ */
.team-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:1.1rem; }
.member{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line);
  aspect-ratio:3/4; background:linear-gradient(180deg,var(--grey-900),var(--space)); isolation:isolate; transition:border-color .5s var(--ease), transform .6s var(--ease), box-shadow .6s var(--ease); }
.member::after{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(180deg, transparent 42%, rgba(8,8,10,.55) 68%, rgba(8,8,10,.97)); transition:background .5s; }
.member img{ width:100%; height:100%; object-fit:cover; object-position:top center;
  filter:grayscale(1) contrast(1.03) brightness(.9); transition:filter .6s var(--ease), transform 1s var(--ease); }
.member:hover{ transform:translateY(-6px); border-color:rgba(184,1,1,.55); box-shadow:0 24px 50px rgba(0,0,0,.45); }
.member:hover img{ filter:grayscale(0) brightness(1); transform:scale(1.07); }
.member .m-info{ position:absolute; z-index:3; inset:auto 0 0 0; padding:1.2rem 1.2rem 1.3rem;
  transform:translateY(10px); transition:transform .5s var(--ease); }
.member:hover .m-info{ transform:translateY(0); }
.member .m-info::before{ content:""; display:block; width:24px; height:3px; border-radius:3px; background:var(--red);
  margin-bottom:.7rem; box-shadow:var(--glow-red); transition:width .5s var(--ease); }
.member:hover .m-info::before{ width:46px; }
.member h4{ font-size:1.02rem; font-weight:700; letter-spacing:-.01em; line-height:1.15; }
.member span{ display:block; color:var(--red-soft); font-size:.76rem; margin-top:.25rem; letter-spacing:.01em; }
/* CEO stays in full colour with a red frame to stand out (uniform tile = clean 5x2 wall) */
.member.lead-ceo{ border-color:rgba(184,1,1,.55); box-shadow:inset 0 0 0 1px rgba(184,1,1,.35); }
.member.lead-ceo img{ filter:grayscale(0) brightness(1); }
.member.lead-ceo .m-info::before{ width:40px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); }
.contact-info h2{ margin-bottom:1.4rem; }
.contact-channels{ display:grid; gap:.8rem; margin-top:2rem; }
.channel{ display:flex; align-items:center; gap:1rem; border:1px solid var(--line); border-radius:14px; padding:1rem 1.2rem; background:rgba(12,12,17,.72); transition:.4s var(--ease); }
.channel:hover{ border-color:var(--red); transform:translateX(6px); background:rgba(184,1,1,.14); }
.channel .ci{ width:44px; height:44px; border-radius:12px; background:rgba(184,1,1,.12); display:grid; place-items:center; color:var(--red-soft); flex:0 0 auto; }
.channel .ci svg{ width:20px; height:20px; }
.channel b{ display:block; font-size:.95rem; } .channel span{ color:var(--muted); font-size:.82rem; }
.form{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.6rem,3vw,2.6rem); background:var(--glass); backdrop-filter:blur(10px); }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-size:.8rem; color:var(--grey-100); margin-bottom:.5rem; letter-spacing:.02em; }
.field input,.field select,.field textarea{
  width:100%; background:rgba(255,255,255,.03); border:1px solid var(--line-strong); border-radius:12px;
  padding:.9rem 1rem; color:#fff; font-family:inherit; font-size:.95rem; transition:.3s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--red); background:rgba(184,1,1,.06); }
.field textarea{ resize:vertical; min-height:110px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-msg{ margin-top:1rem; font-size:.9rem; min-height:1.2em; }
.form-msg.ok{ color:#5fe39a; } .form-msg.err{ color:var(--red-soft); }
.map-embed{ grid-column:1 / -1; margin-top:1rem; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; height:380px; }
.map-embed iframe{ width:100%; height:100%; border:0; filter:grayscale(.4) invert(.92) hue-rotate(180deg) contrast(.95); transition:filter .5s var(--ease); }
.map-embed:hover iframe{ filter:none; }

/* ============================================================
   BLOG / INSIGHTS
   ============================================================ */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.blog-card{ position:relative; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:rgba(12,12,17,.82); display:flex; flex-direction:column; transition:.45s var(--ease); }
.blog-card:hover{ transform:translateY(-6px); border-color:var(--red); box-shadow:0 28px 60px rgba(0,0,0,.45); }
.blog-card .bc-img{ aspect-ratio:16/10; overflow:hidden; }
.blog-card .bc-img img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.blog-card:hover .bc-img img{ transform:scale(1.06); }
.blog-card .bc-body{ padding:1.4rem 1.5rem 1.6rem; display:flex; flex-direction:column; gap:.6rem; flex:1; }
.blog-card h3{ font-size:1.2rem; line-height:1.25; }
.blog-card p{ color:var(--muted); font-size:.92rem; flex:1; }
.blog-card .bc-more{ color:var(--red-soft); font-weight:600; font-size:.9rem; }

/* Article */
.article{ max-width:820px; margin-inline:auto; }
.article-cover{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); margin-bottom:2.2rem; aspect-ratio:16/8; }
.article-cover img{ width:100%; height:100%; object-fit:cover; }
.article-meta{ display:flex; gap:1rem; flex-wrap:wrap; color:var(--muted); font-size:.85rem; margin-bottom:1.4rem; }
.takeaways{ border:1px solid rgba(184,1,1,.34); background:rgba(184,1,1,.08); border-radius:var(--radius); padding:1.4rem 1.6rem; margin:0 0 2rem; }
.takeaways h2{ font-size:1.05rem; letter-spacing:.04em; text-transform:uppercase; color:var(--red-soft); margin-bottom:.8rem; }
.takeaways ul{ display:grid; gap:.55rem; }
.takeaways li{ position:relative; padding-left:1.4rem; color:var(--grey-100); }
.takeaways li::before{ content:"▸"; position:absolute; left:0; color:var(--red); }
.article-body{ font-size:1.06rem; line-height:1.8; color:var(--grey-100); }
.article-body h2{ font-size:clamp(1.5rem,3vw,2rem); margin:2.4rem 0 1rem; color:#fff; letter-spacing:-.01em; }
.article-body h3{ font-size:1.25rem; margin:1.8rem 0 .8rem; color:#fff; }
.article-body p{ margin-bottom:1.2rem; }
.article-body a{ color:var(--red-soft); border-bottom:1px solid rgba(226,58,58,.4); }
.article-body a:hover{ color:#fff; border-color:#fff; }
.article-body ul,.article-body ol{ margin:0 0 1.3rem 1.2rem; display:grid; gap:.5rem; }
.article-body li{ list-style:disc; }
.article-body strong{ color:#fff; }
.article-body table{ width:100%; border-collapse:collapse; margin:1.4rem 0; font-size:.95rem; border:1px solid var(--line); border-radius:12px; overflow:hidden; }
.article-body th,.article-body td{ text-align:left; padding:.8rem 1rem; border-bottom:1px solid var(--line); }
.article-body th{ background:#17171f; color:#fff; font-weight:600; }
.article-body tr:nth-child(even) td{ background:rgba(255,255,255,.02); }
.article-faq{ margin-top:2.6rem; }
.article-faq h2{ font-size:clamp(1.5rem,3vw,2rem); margin-bottom:1.2rem; }
.faq-item{ border:1px solid var(--line); border-radius:var(--radius); padding:1.2rem 1.4rem; margin-bottom:.8rem; background:rgba(12,12,17,.7); }
.faq-item h3{ font-size:1.05rem; margin-bottom:.5rem; color:#fff; }
.faq-item p{ color:var(--muted); font-size:.95rem; }
.article-cta{ margin-top:2.6rem; border:1px solid var(--line); border-radius:var(--radius-lg); padding:2rem; text-align:center; background:linear-gradient(135deg,rgba(120,10,10,.5),rgba(12,12,18,.9)); }
@media (max-width:1024px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .blog-grid{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding-block:4rem 2rem; position:relative; z-index:3; background:rgba(8,8,10,.5); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem; margin-bottom:3rem; }
.footer h5{ font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:1.2rem; }
.footer-links a{ display:block; color:var(--grey-100); padding:.35rem 0; transition:color .3s, padding-left .3s; font-size:.92rem; }
.footer-links a:hover{ color:var(--red-soft); padding-left:.4rem; }
.footer-brand p{ color:var(--muted); font-size:.9rem; max-width:34ch; margin-top:1rem; }
.socials{ display:flex; gap:.6rem; margin-top:1.4rem; }
.socials a{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line-strong); display:grid; place-items:center; transition:.35s var(--ease); }
.socials a:hover{ background:var(--red); border-color:var(--red); transform:translateY(-3px); }
.socials svg{ width:18px; height:18px; }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; padding-top:2rem; border-top:1px solid var(--line); color:var(--muted); font-size:.82rem; }

/* Floating WhatsApp */
.fab-wa{ position:fixed; right:1.4rem; bottom:1.4rem; z-index:45; width:58px; height:58px; border-radius:50%; background:#1faf54; display:grid; place-items:center; box-shadow:0 10px 30px rgba(31,175,84,.5); transition:transform .35s var(--ease); }
.fab-wa:hover{ transform:scale(1.1) translateY(-2px); }
.fab-wa svg{ width:30px; height:30px; }

/* Scroll-to-top */
.to-top{ position:fixed; right:1.55rem; bottom:6.6rem; z-index:45; width:46px; height:46px; border-radius:50%;
  background:var(--glass); border:1px solid var(--line-strong); backdrop-filter:blur(8px);
  display:grid; place-items:center; opacity:0; visibility:hidden; transform:translateY(12px); transition:.4s var(--ease); }
.to-top.show{ opacity:1; visibility:visible; transform:none; }
.to-top:hover{ border-color:var(--red); background:rgba(184,1,1,.16); transform:translateY(-3px); }
.to-top svg{ width:20px; height:20px; color:#fff; }

/* "Coming soon" teaser: real render + dark scrim + glowing badge */
.cs-card{ position:relative; width:100%; height:100%; min-height:300px; overflow:hidden; }
/* heavily blurred render = anticipation / "launching soon" feel */
.cs-card img{ width:100%; height:100%; object-fit:cover; filter:blur(16px) saturate(.9) brightness(.42); transform:scale(1.18); transition:filter .7s var(--ease), transform 1.4s var(--ease); }
.mega-item:hover .cs-card img{ filter:blur(11px) saturate(1) brightness(.55); transform:scale(1.24); }
.cs-card::after{ content:""; position:absolute; inset:0;
  background:radial-gradient(120% 90% at 50% 45%, rgba(184,1,1,.34), transparent 60%), linear-gradient(180deg, rgba(8,8,10,.55), rgba(8,8,10,.85)); }
.cs-card .cs-inner{ position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:1.5rem; }
.cs-badge{ display:inline-flex; align-items:center; gap:.6rem; font-size:.74rem; letter-spacing:.34em; text-transform:uppercase; color:#fff; font-weight:700;
  padding:.6rem 1.3rem; border:1px solid rgba(255,255,255,.34); border-radius:100px; background:rgba(184,1,1,.45); backdrop-filter:blur(6px); box-shadow:var(--glow-red); }
.cs-badge .dot{ width:7px; height:7px; border-radius:50%; background:#fff; box-shadow:0 0 10px #fff; animation:blink 1.6s infinite; }
.cs-card h4{ font-size:clamp(1.7rem,3vw,2.5rem); font-weight:900; letter-spacing:-.02em; margin:1.2rem 0 .45rem; color:#fff; text-shadow:0 2px 26px rgba(0,0,0,.7); }
.cs-card .cs-sub{ font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--grey-100); }

/* ============================================================
   REVIEWS / TESTIMONIALS
   ============================================================ */
.reviews-head{ display:flex; flex-wrap:wrap; align-items:center; gap:1.4rem; justify-content:space-between; margin-bottom:2.4rem; }
.google-rating{ display:flex; align-items:center; gap:1rem; border:1px solid var(--line); border-radius:16px; padding:1rem 1.4rem; background:var(--glass-2); }
.google-rating .g-score{ font-size:2.4rem; font-weight:900; line-height:1; }
.stars{ color:#ffc107; letter-spacing:2px; font-size:1rem; }
.google-rating small{ color:var(--muted); display:block; margin-top:.2rem; font-size:.8rem; }
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.review{ border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem; background:rgba(12,12,17,.8); transition:.4s var(--ease); }
.review:hover{ border-color:var(--red); transform:translateY(-5px); }
.review .stars{ margin-bottom:.9rem; }
.review p{ color:var(--grey-100); font-size:.95rem; margin-bottom:1.2rem; }
.review .r-by{ display:flex; align-items:center; gap:.7rem; }
.review .r-av{ width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--red),var(--red-deep)); display:grid; place-items:center; font-weight:800; color:#fff; font-size:.95rem; }
.review .r-by b{ display:block; font-size:.9rem; } .review .r-by span{ color:var(--muted); font-size:.76rem; }

/* ============================================================
   PAGE HERO (sub pages)
   ============================================================ */
.page-hero{ padding-top:11rem; padding-bottom:3rem; }
.page-hero h1{ font-size:var(--fs-h1); font-weight:900; text-transform:uppercase; letter-spacing:-.03em; }
.crumbs{ display:flex; gap:.5rem; align-items:center; color:var(--muted); font-size:.85rem; margin-bottom:1.5rem; }
.crumbs a:hover{ color:var(--red-soft); } .crumbs span{ color:var(--muted); }

/* Project detail blocks (projects.html) */
.project-block{ padding-block:clamp(3rem,7vh,6rem); border-top:1px solid var(--line); }
.pb-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1.5rem; margin-bottom:2rem; }
.pb-head h2{ font-size:var(--fs-h3); }
.pb-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1rem; }
.pb-tags li{ font-size:.74rem; padding:.35rem .75rem; border:1px solid var(--line); border-radius:100px; color:var(--grey-100); }
.pb-cta{ display:flex; gap:.6rem; flex-wrap:wrap; align-items:center; }
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:.8rem; }
.gallery a{ border-radius:14px; overflow:hidden; aspect-ratio:4/3; border:1px solid var(--line); }
.gallery a:first-child{ grid-column:span 2; grid-row:span 2; aspect-ratio:auto; }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
.gallery a:hover img{ transform:scale(1.07); }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:120; background:rgba(8,8,10,.94); backdrop-filter:blur(8px); display:none; align-items:center; justify-content:center; padding:2rem; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:12px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lightbox .lb-close{ position:absolute; top:1.5rem; right:1.5rem; width:48px; height:48px; border-radius:50%; border:1px solid var(--line-strong); font-size:1.5rem; }
.lightbox .lb-nav{ position:absolute; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:1px solid var(--line-strong); background:var(--glass); font-size:1.4rem; }
.lightbox .lb-prev{ left:1.5rem; } .lightbox .lb-next{ right:1.5rem; }

/* YouTube video modal */
.yt-modal{ position:fixed; inset:0; z-index:130; background:rgba(8,8,10,.95); backdrop-filter:blur(10px); display:none; align-items:center; justify-content:center; padding:2rem; }
.yt-modal.open{ display:flex; }
.yt-frame{ position:relative; width:min(1000px,92vw); aspect-ratio:16/9; border-radius:14px; overflow:hidden; box-shadow:0 30px 80px rgba(0,0,0,.6); border:1px solid var(--line-strong); }
.yt-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.yt-modal .yt-close{ position:absolute; top:1.4rem; right:1.4rem; width:48px; height:48px; border-radius:50%; border:1px solid var(--line-strong); font-size:1.5rem; background:var(--glass); }

/* ============================================================
   REVEAL ANIMATIONS — driven by IntersectionObserver (.is-in).
   Content is hidden ONLY while JS is active (html.js); no-JS users
   and the .reveal-all failsafe always see everything. Uses keyframe
   animations (not transitions) so element hover transforms are never
   clobbered.
   ============================================================ */
@keyframes fxRise{ from{ opacity:0; transform:translateY(34px) } to{ opacity:1; transform:none } }
@keyframes fxFade{ from{ opacity:0 } to{ opacity:1 } }
@keyframes lineRise{ from{ transform:translateY(110%) } to{ transform:none } }

html.js .fx{ opacity:0; }
html.js .fx.is-in{ opacity:1; animation:fxRise .9s var(--ease); } /* settles visible even if animation is throttled */

html.js [data-stagger] > *{ opacity:0; }
html.js [data-stagger].is-in > *{ animation:fxFade .7s var(--ease) both; }
html.js [data-stagger].is-in > *:nth-child(2){ animation-delay:.06s }
html.js [data-stagger].is-in > *:nth-child(3){ animation-delay:.12s }
html.js [data-stagger].is-in > *:nth-child(4){ animation-delay:.18s }
html.js [data-stagger].is-in > *:nth-child(5){ animation-delay:.24s }
html.js [data-stagger].is-in > *:nth-child(6){ animation-delay:.30s }
html.js [data-stagger].is-in > *:nth-child(7){ animation-delay:.36s }
html.js [data-stagger].is-in > *:nth-child(n+8){ animation-delay:.42s }

html.js [data-split] .reveal-line > span{ transform:translateY(110%); }
html.js [data-split].is-in .reveal-line > span{ animation:lineRise 1s var(--ease) both; }
html.js [data-split].is-in .reveal-line:nth-child(2) > span{ animation-delay:.09s }
html.js [data-split].is-in .reveal-line:nth-child(3) > span{ animation-delay:.18s }

/* Hard failsafe — if the app never boots, reveal everything */
html.reveal-all .fx{ opacity:1!important; transform:none!important; animation:none!important; }
html.reveal-all [data-stagger] > *{ opacity:1!important; animation:none!important; }
html.reveal-all [data-split] .reveal-line > span{ transform:none!important; animation:none!important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .services-grid{ grid-template-columns:repeat(2,1fr); }
  .team-grid{ grid-template-columns:repeat(3,1fr); }
  .video-grid{ grid-template-columns:repeat(2,1fr); }
  .reviews-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .blocks-grid{ grid-template-columns:repeat(4,1fr); }
}
@media (max-width:860px){
  .nav-links{ display:none; }
  .nav .nav-cta .btn:not(.nav-toggle){ display:none; }
  .nav-toggle{ display:flex; }
  .about-grid,.ceo-card,.inv-teaser,.contact-grid{ grid-template-columns:1fr; }
  .mega-item{ grid-template-columns:1fr; }
  .mega-item:nth-child(even){ direction:ltr; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .reviews-grid{ grid-template-columns:1fr; }
  .proj-grid{ grid-template-columns:1fr; }
  .ceo-card{ text-align:left; }
  .gallery a:first-child{ grid-column:span 2; }
}
@media (max-width:560px){
  .services-grid,.team-grid,.video-grid,.footer-top{ grid-template-columns:1fr 1fr; }
  .pillars{ grid-template-columns:1fr; }
  .blocks-grid{ grid-template-columns:repeat(3,1fr); }
  .member.lead-ceo{ grid-column:span 2; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .form-row{ grid-template-columns:1fr; }
}

/* ============================================================
   ACCESSIBILITY / REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; scroll-behavior:auto!important; }
  html.js .fx{ opacity:1; transform:none; animation:none; }
  html.js [data-stagger] > *{ opacity:1; animation:none; }
  html.js [data-split] .reveal-line > span{ transform:none; animation:none; }
  #bg-canvas{ display:none; }
  .scene-veil{ background:radial-gradient(120% 80% at 50% 0%, rgba(184,1,1,.12), transparent 55%), var(--space); }
}
:focus-visible{ outline:2px solid var(--red-bright); outline-offset:3px; border-radius:4px; }
.skip-link{ position:absolute; left:-9999px; top:0; z-index:300; background:var(--red); color:#fff; padding:.8rem 1.2rem; border-radius:0 0 10px 0; }
.skip-link:focus{ left:0; }
.noscript-banner{ background:var(--red); color:#fff; text-align:center; padding:.8rem; font-size:.9rem; position:relative; z-index:80; }
