﻿/* ═══════════════════════════════════════════════════
   SRI MANISHAA HOMES – FRESH UI 2025
   Color Palette: Deep Indigo + Warm Amber/Gold
   NO blue, red, or green
═══════════════════════════════════════════════════ */

/* ── CSS VARIABLES ── */
:root {
  --indigo:      #3d1f8e;
  --indigo-dark: #2a1260;
  --indigo-mid:  #5a35b8;
  --indigo-soft: #ece6ff;
  --amber:       #f5a623;
  --amber-dark:  #d4880e;
  --amber-soft:  #fff8e8;
  --charcoal:    #1a1428;
  --ink:         #2e2640;
  --grey:        #7a7090;
  --border:      #e8e2f5;
  --white:       #ffffff;
  --off-white:   #faf8ff;
  --shadow-sm:   0 4px 16px rgba(61,31,142,0.10);
  --shadow-md:   0 8px 32px rgba(61,31,142,0.15);
  --shadow-lg:   0 20px 60px rgba(61,31,142,0.22);
  --radius:      14px;
  --transition:  0.36s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; height:100%; }
body {
  font-family:'Poppins','Segoe UI',sans-serif;
  color:var(--ink); background:var(--white);
  overflow-x:hidden; min-height:100%;
}
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; display:block; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--off-white); }
::-webkit-scrollbar-thumb { background:var(--indigo-mid); border-radius:4px; }

/* ── DETAIL ITEM ICONS ── */
.di-loc, .di-bhk {
  font-style: normal;
  font-size: 13px;
  margin-right: 2px;
}

/* ── SCROLL PROGRESS BAR ── */
#scroll-progress-bar {
  position:fixed; top:0; left:0; height:3px; width:0;
  background:linear-gradient(90deg,var(--indigo),var(--amber));
  z-index:9999; transition:width 0.1s linear;
  pointer-events:none;
}

/* ═══════════ SHARED / SECTION ═══════════ */
section { padding:96px 0; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

.section-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  color:var(--indigo); margin-bottom:14px;
}
.section-tag::before {
  content:''; width:24px; height:2px;
  background:var(--amber); border-radius:2px; flex-shrink:0;
}
.section-heading {
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(26px,3.5vw,42px);
  font-weight:800; color:var(--charcoal); line-height:1.2;
  margin-bottom:14px;
}
.section-heading em { color:var(--indigo); font-style:italic; }
.accent-bar {
  width:56px; height:4px;
  background:linear-gradient(90deg,var(--indigo),var(--amber));
  border-radius:2px; margin-bottom:40px;
}
.section-head { margin-bottom:52px; }
.section-head.centered { text-align:center; }
.section-head.centered .section-tag { justify-content:center; display:flex; }
.section-head.centered .accent-bar { margin:0 auto 40px; }

/* ── Buttons ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--indigo); color:var(--white);
  padding:13px 30px; border-radius:50px; font-size:14px; font-weight:600;
  transition:var(--transition);
}
.btn-primary:hover { background:var(--indigo-dark); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  border:2px solid var(--border); color:var(--ink);
  padding:11px 28px; border-radius:50px; font-size:14px; font-weight:600;
  transition:var(--transition);
}
.btn-ghost:hover { border-color:var(--indigo); color:var(--indigo); transform:translateY(-2px); }

/* ── Reveal on scroll ── */
.reveal {
  opacity:0; transform:translateY(36px);
  transition:opacity 0.7s ease, transform 0.7s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left {
  opacity:0; transform:translateX(-48px);
  transition:opacity 0.8s ease, transform 0.8s ease;
}
.reveal-left.visible { opacity:1; transform:translateX(0); }
.reveal-right {
  opacity:0; transform:translateX(48px);
  transition:opacity 0.8s ease, transform 0.8s ease;
}
.reveal-right.visible { opacity:1; transform:translateX(0); }

/* ═══════════ NAVBAR ═══════════ */
#navbar {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  background: #ffffff;
  box-shadow:0 2px 16px rgba(0,0,0,0.08);
  transition:background 0.4s ease, box-shadow 0.4s ease;
}
#navbar.scrolled {
  background: #ffffff;
  box-shadow:0 4px 24px rgba(0,0,0,0.12);
}

/* Navbar link colors — dark on white */
#navbar .nav-links a {
  color: var(--ink);
}
#navbar .nav-links a:hover,
#navbar .nav-links a.active {
  color: var(--indigo);
  background: rgba(61,31,142,0.06);
}
#navbar .nav-links a::after { background: var(--indigo); }
#navbar .hamburger span { background: var(--ink); }
#navbar .nav-cta {
  background: var(--indigo) !important;
  color: var(--white) !important;
}
#navbar .nav-cta:hover { background: var(--indigo-dark) !important; }
.nav-container {
  max-width:1280px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.logo-img { height:52px; width:auto; object-fit:contain; }
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-links a {
  padding:8px 14px; font-size:14px; font-weight:500;
  color:var(--ink); border-radius:8px; transition:var(--transition);
  position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:4px; left:50%; transform:translateX(-50%);
  width:0; height:2px; background:var(--indigo); border-radius:2px;
  transition:width var(--transition);
}
.nav-links a:hover, .nav-links a.active { color:var(--indigo); }
.nav-links a:hover::after, .nav-links a.active::after { width:55%; }
.nav-cta {
  background:var(--indigo) !important;
  color:var(--white) !important;
  border-radius:50px !important;
  padding:10px 22px !important;
  font-weight:600 !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { background:var(--indigo-dark) !important; transform:translateY(-1px); box-shadow:var(--shadow-sm); }

.hamburger { display:none; flex-direction:column; gap:5px; padding:4px; }
.hamburger span { display:block; width:26px; height:2.5px; background:var(--ink); border-radius:2px; transition:var(--transition); }
.hamburger.open span:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

/* ═══════════ DROPDOWN MENUS ═══════════ */
.nav-links li { position:relative; }

.nav-links li .dropdown {
  display:none;
  position:absolute;
  top:calc(100% + 8px);
  left:50%;
  transform:translateX(-50%);
  background:#fff;
  border-radius:12px;
  box-shadow:0 8px 32px rgba(0,0,0,0.13);
  min-width:210px;
  padding:8px 0;
  z-index:2000;
  list-style:none;
  border:1px solid rgba(61,31,142,0.08);
  animation:dropFadeIn 0.18s ease;
}

@keyframes dropFadeIn {
  from { opacity:0; transform:translateX(-50%) translateY(-6px); }
  to   { opacity:1; transform:translateX(-50%) translateY(0); }
}

/* Pointer arrow on top of dropdown */
.nav-links li .dropdown::before {
  content:'';
  position:absolute;
  top:-7px;
  left:50%;
  transform:translateX(-50%);
  border-left:7px solid transparent;
  border-right:7px solid transparent;
  border-bottom:7px solid #fff;
  filter:drop-shadow(0 -2px 2px rgba(0,0,0,0.06));
}

.nav-links li .dropdown li { list-style:none; }

.nav-links li .dropdown li a {
  display:block;
  padding:10px 20px;
  font-size:13.5px;
  font-weight:500;
  color:var(--ink);
  border-radius:0;
  white-space:nowrap;
  transition:background 0.18s ease, color 0.18s ease;
}
.nav-links li .dropdown li a::after { display:none !important; }
.nav-links li .dropdown li a:hover {
  background:rgba(61,31,142,0.07);
  color:var(--indigo);
  padding-left:26px;
}

/* Show on hover */
.nav-links li:hover > .dropdown { display:block; }

/* Dropdown trigger arrow indicator */
.nav-links li.has-dropdown > a::before {
  content:'';
  display:inline-block;
  width:0; height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:4px solid currentColor;
  margin-left:5px;
  vertical-align:middle;
  transition:transform 0.2s ease;
}
.nav-links li.has-dropdown:hover > a::before {
  transform:rotate(180deg);
}

/* Mobile dropdown */
@media (max-width:900px) {
  .nav-links li .dropdown {
    position:static;
    transform:none;
    box-shadow:none;
    border:none;
    border-radius:0;
    background:rgba(61,31,142,0.04);
    padding:0;
    animation:none;
    display:none;
    min-width:unset;
  }
  .nav-links li .dropdown::before { display:none; }
  .nav-links li.has-dropdown.open > .dropdown { display:block; }
  .nav-links li .dropdown li a {
    padding:9px 28px;
    font-size:13px;
    border-left:3px solid var(--indigo);
  }
}

/* ═══════════ HERO – SPLIT SCREEN ═══════════ */
#hero {
  padding:0 !important;
  margin-top:72px;
  width:100%;
  height:calc(100vh - 72px);
  min-height:560px;
  display:grid;
  grid-template-columns:1fr 1fr;
  overflow:hidden;
  position:relative;
}

/* ── LEFT content panel ── */
.hs-left {
  background: #1e1060;
  display:flex; align-items:stretch; justify-content:center;
  position:relative; overflow:hidden; z-index:1;
}

/* Isometric cube grid — real diamond/rhombus tiling */
.hs-iso-grid {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-color: #1e1060;
  background-image:
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,0.18) 0px, rgba(255,255,255,0.18) 1px,
      transparent 1px, transparent 50px
    ),
    repeating-linear-gradient(
      60deg,
      rgba(255,255,255,0.18) 0px, rgba(255,255,255,0.18) 1px,
      transparent 1px, transparent 50px
    ),
    repeating-linear-gradient(
      120deg,
      rgba(255,255,255,0.18) 0px, rgba(255,255,255,0.18) 1px,
      transparent 1px, transparent 50px
    );
}

/* Vignette over the grid */
.hs-left::after {
  content:'';
  position:absolute; inset:0; z-index:1;
  pointer-events:none;
}

.hs-left::before { display:none; }

.hs-left-inner {
  padding:40px 52px;
  position:relative; z-index:3;
  animation:hsFadeUp 0.8s 0.1s ease both;
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  text-align:center;
  width:100%;
}
@keyframes hsFadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

.hs-badge {
  display:inline-flex; align-items:center; gap:8px;
  align-self:center;
  background:rgba(245,166,35,0.12);
  border:1px solid rgba(245,166,35,0.35);
  color:var(--amber);
  font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  padding:7px 16px; border-radius:50px; margin-bottom:20px;
  opacity:0;
  animation: fadeInUp 0.6s ease 0.1s forwards;
}
.hs-badge-dot {
  width:7px; height:7px; border-radius:50%; background:var(--amber); flex-shrink:0;
  animation:dotPulse 1.8s infinite;
}
@keyframes dotPulse { 0%,100%{transform:scale(1);opacity:1;} 50%{transform:scale(2);opacity:0.3;} }

.hs-title {
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(38px,4.2vw,64px);
  font-weight:800; color:var(--white); line-height:1.15;
  margin-bottom:14px;
  overflow:visible;
}

/* Word slide-up animation */
.hs-word {
  display:inline-block;
  opacity:0;
  transform:translateY(40px);
  animation: wordUp 0.65s cubic-bezier(.22,.68,0,1.2) forwards;
  animation-delay: var(--d, 0s);
}
@keyframes wordUp {
  to { opacity:1; transform:translateY(0); }
}

/* Typewriter for "in Chennai" */
.hs-type-wrap {
  display:block;
  overflow:hidden;
  text-align:center;
}
.hs-typewriter {
  display:inline-block;
  color:var(--amber); font-style:italic;
  white-space:nowrap;
  overflow:hidden;
  max-width:0;
  width:auto;
  border-right:3px solid var(--amber);
  vertical-align:bottom;
  animation:
    typing 1.2s steps(10, end) 0.6s forwards,
    blink 0.75s step-end 0.6s 6,
    hideCursor 0s 5.7s forwards;
}
@keyframes typing {
  from { max-width:0; }
  to   { max-width:600px; }
}
@keyframes blink {
  0%,100% { border-color:var(--amber); }
  50%      { border-color:transparent; }
}
@keyframes hideCursor {
  to { border-color:transparent; border-width:0; }
}

/* Generic fade-in-up */
.hs-fadein {
  opacity:0;
  transform:translateY(20px);
  animation: fadeInUp 0.7s ease forwards;
  animation-delay: var(--d, 0.5s);
}
@keyframes fadeInUp {
  to { opacity:1; transform:translateY(0); }
}

.hs-sub {
  font-size:15px; line-height:1.8;
  color:rgba(255,255,255,0.62); margin-bottom:24px;
}

.hs-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:28px; justify-content:center;
  opacity:0; animation: fadeInUp 0.7s ease 0.9s forwards;
}

.hs-btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--amber); color:var(--charcoal);
  padding:13px 28px; border-radius:50px;
  font-size:14px; font-weight:700;
  box-shadow:0 6px 24px rgba(245,166,35,0.40);
  transition:var(--transition);
}
.hs-btn-primary:hover { background:var(--amber-dark); transform:translateY(-2px); box-shadow:0 10px 32px rgba(245,166,35,0.55); }

.hs-btn-outline {
  display:inline-flex; align-items:center;
  border:2px solid rgba(255,255,255,0.28); color:var(--white);
  padding:11px 26px; border-radius:50px;
  font-size:14px; font-weight:600;
  transition:var(--transition); backdrop-filter:blur(4px);
}
.hs-btn-outline:hover { border-color:var(--amber); color:var(--amber); transform:translateY(-2px); }

.hs-stats {
  display:flex; align-items:center; justify-content:center;
  padding-top:20px;
  width:100%;
  border-top:1px solid rgba(255,255,255,0.10);
}
.hs-stat { flex:1; text-align:center; }
.hs-stat strong {
  display:block; font-family:'Playfair Display',serif;
  font-size:32px; font-weight:800; color:var(--amber);
  line-height:1.1; margin-bottom:3px;
}
.hs-stat span {
  font-size:11px; color:rgba(255,255,255,0.48);
  text-transform:uppercase; letter-spacing:1px; font-weight:500;
}
.hs-stat-div {
  width:1px; height:40px;
  background:rgba(255,255,255,0.12); margin:0 20px;
}

/* ── Scrolling ticker ── */
.hs-ticker {
  margin-top:16px;
  overflow:hidden;
  width:100%;
  border-top:1px solid rgba(255,255,255,0.10);
  padding-top:14px;
  mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.hs-ticker-track {
  display:flex; align-items:center; justify-content:center;
  width:max-content;
  animation: tickerScroll 18s linear infinite;
}
.hs-ticker-track span {
  font-size:10px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; color:rgba(255,255,255,0.40);
  white-space:nowrap; padding:0 14px;
}
.hs-ticker-track em {
  font-style:normal; color:var(--amber);
  font-size:9px; flex-shrink:0;
}
@keyframes tickerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── RIGHT image panel ── */
.hs-right { position:relative; overflow:hidden; }

.hs-slides { position:absolute; inset:0; }
.hs-slide {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0;
  transition:opacity 1.2s ease, transform 9s ease;
  transform:scale(1.05);
}
.hs-slide.active { opacity:1; transform:scale(1); }

.hs-img-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(to right, rgba(42,18,96,0.30) 0%, transparent 45%);
}

/* Arrows */
.hs-arrow {
  position:absolute; z-index:3;
  top:50%; transform:translateY(-50%);
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,0.14);
  backdrop-filter:blur(8px);
  border:1.5px solid rgba(255,255,255,0.25);
  color:var(--white);
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition); cursor:pointer;
}
.hs-arrow:hover { background:var(--amber); border-color:var(--amber); color:var(--charcoal); }
.hs-arrow--prev { left:16px; }
.hs-arrow--next { right:16px; }

/* Dots */
.hs-dots {
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  z-index:3; display:flex; gap:8px; align-items:center;
}
.hs-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,0.35);
  cursor:pointer; transition:var(--transition);
}
.hs-dot.active {
  background:var(--amber); transform:scale(1.4);
  box-shadow:0 0 0 3px rgba(245,166,35,0.25);
}

/* Floating location pill */
.hs-float-label {
  position:absolute; top:24px; left:20px; z-index:3;
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,0.14);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.22);
  color:var(--white); font-size:11px; font-weight:600;
  padding:6px 14px; border-radius:50px;
}

/* Vertical scrolling text strip on right panel */
.hs-vert-ticker {
  position:absolute; right:0; top:0; bottom:0; z-index:3;
  width:36px;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:rgba(245,166,35,0.85);
  mask-image: linear-gradient(180deg, transparent, black 12%, black 88%, transparent);
  -webkit-mask-image: linear-gradient(180deg, transparent, black 12%, black 88%, transparent);
}
.hs-vert-track {
  display:flex; flex-direction:column; align-items:center; gap:28px;
  width:max-content;
  animation: vertScroll 12s linear infinite;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
.hs-vert-track span {
  font-size:10px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:var(--charcoal);
  white-space:nowrap;
}
@keyframes vertScroll {
  from { transform: translateY(0); }
  to   { transform: translateY(-50%); }
}

/* Navbar transparent over hero — not needed, handled above */

/* ═══════════ STATS ═══════════ */
#stats {
  background: linear-gradient(135deg, #0f0820 0%, #1a1428 100%);
  padding: 64px 0;
}
.stats-inner {
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 32px; text-align: center;
}
.stat-item { color: var(--white); }
.stat-num {
  font-size: 52px; font-weight: 800;
  font-family: 'Playfair Display', serif;
  background: linear-gradient(135deg, var(--indigo-mid), var(--amber));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; display: block; line-height: 1.1;
}
.stat-label {
  font-size: 13px; color: rgba(255,255,255,0.60);
  margin-top: 8px; font-weight: 500; text-transform: uppercase; letter-spacing: 1px;
}
@media (max-width: 700px) {
  .stats-inner { grid-template-columns: repeat(2,1fr); gap: 24px; }
}

/* ═══════════ ABOUT – FULL WIDTH TEXT ONLY ═══════════ */
#about { background:var(--off-white); padding:96px 0; }
.abt-wrap {
  max-width:1200px; margin:0 auto; padding:0 24px;
  display:flex; flex-direction:column; gap:64px;
}

/* ── Top intro ── */
.abt-top { text-align:center; max-width:820px; margin:0 auto; }

.abt-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  margin-bottom:20px;
}
.abt-eyebrow-line {
  display:block; width:32px; height:3px;
  background:var(--amber); border-radius:2px;
}
.abt-eyebrow span:last-child {
  font-size:11px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--indigo);
}

.abt-heading {
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(28px,3.5vw,46px);
  font-weight:800; color:var(--charcoal); line-height:1.2;
  margin-bottom:20px;
}
.abt-heading em { color:var(--indigo); font-style:italic; }

.abt-desc {
  font-size:15px; line-height:1.9; color:var(--grey);
  max-width:700px; margin:0 auto;
}
.abt-desc b { color:var(--charcoal); font-weight:600; }

/* ── 4 feature cards ── */
.abt-cards {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.abt-card {
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:20px;
  padding:32px 24px 28px;
  text-align:center;
  position:relative; overflow:hidden;
  transition:var(--transition);
  cursor:default;
}
.abt-card::before {
  content:'';
  position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--indigo),var(--amber));
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.4s ease;
}
.abt-card:hover::before { transform:scaleX(1); }
.abt-card:hover {
  border-color:var(--indigo);
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
}
.abt-card-icon {
  width:56px; height:56px; border-radius:14px;
  background:var(--indigo-soft); color:var(--indigo);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 16px;
  transition:var(--transition);
}
.abt-card-icon svg { width:28px; height:28px; }
.abt-card:hover .abt-card-icon { background:var(--indigo); color:var(--white); }
.abt-card-num {
  position:absolute; top:16px; right:18px;
  font-size:36px; font-weight:900; color:var(--indigo-soft);
  font-family:'Playfair Display',serif; line-height:1;
  transition:color var(--transition);
}
.abt-card:hover .abt-card-num { color:var(--border); }
.abt-card h4 {
  font-size:15px; font-weight:700; color:var(--charcoal);
  margin-bottom:10px;
}
.abt-card p { font-size:13px; color:var(--grey); line-height:1.7; }

/* ── Bottom: quote + CTA ── */
.abt-bottom {
  display:flex; align-items:center; justify-content:space-between;
  gap:40px; flex-wrap:wrap;
  padding:36px 48px;
  background:var(--indigo);
  border-radius:20px;
}
.abt-quote { flex:1; min-width:260px; display:flex; align-items:flex-start; gap:16px; }
.abt-quote-mark {
  font-size:64px; font-family:Georgia,serif;
  color:var(--amber); line-height:0.75; flex-shrink:0;
  margin-top:4px;
}
.abt-quote p {
  font-size:15px; line-height:1.75; color:var(--amber);
  font-style:italic; margin-bottom:8px;
}
.abt-quote cite { font-size:11px; font-weight:700; color:var(--amber); letter-spacing:1.5px; text-transform:uppercase; }

.abt-ctas { display:flex; gap:14px; flex-shrink:0; flex-wrap:wrap; }
.abt-btn-solid {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--amber); color:var(--charcoal);
  padding:13px 28px; border-radius:50px;
  font-size:14px; font-weight:700;
  transition:var(--transition);
  box-shadow:0 4px 18px rgba(245,166,35,0.35);
  white-space:nowrap;
}
.abt-btn-solid:hover { background:var(--amber-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(245,166,35,0.45); }
.abt-btn-outline {
  display:inline-flex; align-items:center;
  border:2px solid rgba(255,255,255,0.35); color:var(--white);
  padding:11px 26px; border-radius:50px;
  font-size:14px; font-weight:600;
  transition:var(--transition);
  white-space:nowrap;
}
.abt-btn-outline:hover { border-color:var(--amber); color:var(--amber); transform:translateY(-2px); }

/* ═══════════ SERVICES ═══════════ */
#services { background:var(--white); }
.services-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.srv-card {
  padding:40px 30px 36px;
  background:var(--off-white);
  border:1.5px solid var(--border);
  border-radius:20px;
  position:relative; overflow:hidden;
  transition:var(--transition);
}
.srv-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,var(--indigo-dark),var(--indigo));
  opacity:0; transition:opacity var(--transition); border-radius:20px;
}
.srv-card:hover::before { opacity:1; }
.srv-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:transparent; }
.srv-card > * { position:relative; z-index:1; }
.srv-num {
  position:absolute; top:16px; right:22px; z-index:0;
  font-size:52px; font-weight:900; line-height:1;
  color:var(--indigo-soft);
  font-family:'Playfair Display',serif;
  transition:color var(--transition);
}
.srv-card:hover .srv-num { color:rgba(255,255,255,0.07); }
.srv-icon {
  width:56px; height:56px; border-radius:14px;
  background:var(--indigo-soft); display:flex; align-items:center; justify-content:center;
  color:var(--indigo); margin-bottom:22px;
  transition:background var(--transition),color var(--transition);
}
.srv-icon svg { width:28px; height:28px; }
.srv-card:hover .srv-icon { background:rgba(255,255,255,0.15); color:var(--amber); }
.srv-card h3 { font-size:18px; font-weight:700; color:var(--charcoal); margin-bottom:12px; transition:color var(--transition); }
.srv-card:hover h3 { color:var(--white); }
.srv-card p { font-size:14px; color:var(--grey); line-height:1.75; margin-bottom:24px; transition:color var(--transition); }
.srv-card:hover p { color:rgba(255,255,255,0.72); }
.srv-link { font-size:13px; font-weight:700; color:var(--indigo); display:inline-flex; align-items:center; gap:6px; transition:color var(--transition); }
.srv-card:hover .srv-link { color:var(--amber); }
.srv-hover-bar {
  position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--indigo),var(--amber));
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.4s ease;
}
.srv-card:hover .srv-hover-bar { transform:scaleX(1); }

/* ═══════════ PROJECTS ═══════════ */
#projects { background:var(--off-white); }
.projects-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px; margin-bottom:48px;
}

/* 7-card clean 3-col grid */
.projects-grid-7 {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px; margin-bottom:48px;
}
.projects-grid-7 .proj-card-full {
  grid-column: 1 / -1;
}
.projects-grid-7 .proj-card-full .proj-img-wrap {
  height:320px;
}
.projects-grid-7 .proj-card-full .proj-img-wrap img {
  object-position:center 30%;
}
  gap:22px; margin-bottom:48px;
}
.proj-card {
  border-radius:18px; overflow:hidden;
  background:var(--white);
  box-shadow:var(--shadow-sm);
  border:1px solid var(--border);
  transition:var(--transition);
  will-change:transform;
}
.proj-card-wide { grid-column:span 2; }
.proj-card:hover { box-shadow:var(--shadow-lg); border-color:transparent; }
.proj-img-wrap { position:relative; overflow:hidden; height:220px; }
.proj-card-wide .proj-img-wrap { height:250px; }
.proj-img-wrap img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.6s ease; }
.proj-card:hover .proj-img-wrap img { transform:scale(1.08); }
.proj-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(61,31,142,0.72) 0%,transparent 55%);
  display:flex; align-items:flex-end; justify-content:center; padding:24px;
  opacity:0; transition:var(--transition);
}
.proj-card:hover .proj-overlay { opacity:1; }
.proj-overlay-btn {
  background:var(--amber); color:var(--charcoal);
  padding:9px 24px; border-radius:50px; font-size:13px; font-weight:700;
  transition:transform 0.2s;
}
.proj-overlay-btn:hover { transform:scale(1.05); }
.proj-badge {
  position:absolute; top:14px; left:14px;
  padding:5px 14px; border-radius:50px;
  font-size:11px; font-weight:700; letter-spacing:1px;
}
.proj-badge.ongoing { background:var(--amber); color:var(--charcoal); }
.proj-badge.done    { background:var(--indigo); color:var(--white); }
.proj-info { padding:20px; }
.proj-num { font-size:11px; font-weight:700; color:var(--grey); letter-spacing:2px; margin-bottom:6px; display:block; }
.proj-info h3 { font-size:16px; font-weight:700; color:var(--charcoal); margin-bottom:6px; }
.proj-info p  { font-size:13px; color:var(--grey); margin-bottom:14px; }
.proj-link { font-size:13px; font-weight:700; color:var(--indigo); transition:color var(--transition); }
.proj-link:hover { color:var(--amber); }
.proj-ctas { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* ═══════════ VIDEOS ═══════════ */
#videos { background:var(--white); }
.video-tabs { display:flex; gap:12px; justify-content:center; margin-bottom:36px; flex-wrap:wrap; }
.vtab {
  padding:10px 26px; border-radius:50px;
  font-size:14px; font-weight:600;
  border:2px solid var(--border); color:var(--grey);
  transition:var(--transition);
}
.vtab.active, .vtab:hover { border-color:var(--indigo); background:var(--indigo); color:var(--white); }

.video-track-wrap { position:relative; display:none; }
.video-track-wrap.active { display:block; }
.video-track {
  display:flex; gap:22px;
  overflow-x:auto; scroll-snap-type:x mandatory;
  padding:8px 4px 24px;
  -ms-overflow-style:none; scrollbar-width:none;
}
.video-track::-webkit-scrollbar { display:none; }
.vid-card {
  flex:0 0 320px; scroll-snap-align:start;
  border-radius:16px; overflow:hidden;
  background:var(--off-white); border:1.5px solid var(--border);
  transition:var(--transition);
}
.vid-card:hover { box-shadow:var(--shadow-md); border-color:var(--indigo); transform:translateY(-4px); }
.vid-player { width:100%; height:200px; object-fit:cover; display:block; background:#000; }
.vid-placeholder {
  height:200px; background:var(--indigo-soft);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; color:var(--grey);
}
.vid-placeholder span { font-size:40px; }
.vid-placeholder p { font-size:13px; text-align:center; line-height:1.5; }
.vid-info { display:flex; align-items:center; gap:12px; padding:16px; }
.vid-n {
  font-size:22px; font-weight:800; color:var(--indigo-soft);
  font-family:'Playfair Display',serif; flex-shrink:0;
}
.vid-info strong { display:block; font-size:14px; font-weight:700; color:var(--charcoal); }
.vid-info small  { font-size:11px; color:var(--grey); margin-top:2px; display:block; }
.vid-badge {
  margin-left:auto; background:var(--amber); color:var(--charcoal);
  font-size:10px; font-weight:700; padding:4px 10px; border-radius:50px;
}
.vtr-btn {
  position:absolute; top:calc(50% - 20px); transform:translateY(-50%);
  width:42px; height:42px; border-radius:50%;
  background:var(--white); border:2px solid var(--border);
  font-size:18px; color:var(--indigo);
  box-shadow:var(--shadow-sm);
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition); z-index:2;
}
.vtr-left  { left:-21px; }
.vtr-right { right:-21px; }
.vtr-btn:hover { background:var(--indigo); color:var(--white); border-color:var(--indigo); }

/* ═══════════ GALLERY ═══════════ */
#gallery { background:var(--off-white); padding-bottom:0; }
.gallery-mosaic {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  grid-template-rows:220px 220px;
  gap:10px;
  padding:0 24px 24px;
  max-width:1200px; margin:0 auto;
}
.gm-item { position:relative; overflow:hidden; border-radius:14px; cursor:pointer; }
.gm-big  { grid-row:span 2; }
.gm-tall { grid-row:span 2; }
.gm-col  { display:contents; }
.gm-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.6s ease; }
.gm-item:hover img { transform:scale(1.08); }
.gm-cap {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(42,18,96,0.80) 0%,transparent 55%);
  display:flex; align-items:flex-end; padding:16px;
  opacity:0; transition:var(--transition);
}
.gm-item:hover .gm-cap { opacity:1; }
.gm-cap span { color:var(--white); font-size:12px; font-weight:600; letter-spacing:0.5px; }
.gallery-view-all { text-align:center; padding:40px 0; }

/* ═══════════ TESTIMONIALS ═══════════ */
#testimonials { background:var(--white); position:relative; overflow:hidden; }
.testi-bg-shape {
  position:absolute; right:-200px; top:-100px;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(61,31,142,0.05) 0%,transparent 70%);
  pointer-events:none;
}
.testi-outer { position:relative; overflow:hidden; padding:8px 0 0; }
.testi-slider {
  display:flex; gap:20px;
  transition:transform 0.65s cubic-bezier(.4,0,.2,1);
}
.testi-card {
  flex:0 0 calc(33.333% - 14px); padding:28px 28px 24px;
  background:var(--off-white); border-radius:16px;
  margin:0 16px; border:1.5px solid var(--border);
}
.tc-stars { color:var(--amber); font-size:15px; margin-bottom:6px; letter-spacing:2px; }
.tc-quote {
  font-size:44px; color:var(--indigo); opacity:0.14; line-height:0.8;
  margin-bottom:8px; font-family:Georgia,serif;
}
.testi-card p { font-size:13px; line-height:1.8; color:var(--grey); margin-bottom:20px; }
.tc-author { display:flex; align-items:center; gap:14px; }
.tc-avatar {
  width:48px; height:48px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--indigo),var(--indigo-mid));
  color:var(--white); font-size:20px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}
.tc-author h5 { font-size:15px; font-weight:700; color:var(--charcoal); }
.tc-author span { font-size:12px; color:var(--grey); }
.testi-nav { display:flex; gap:10px; justify-content:center; margin-top:36px; }
.testi-nav button {
  width:46px; height:46px; border-radius:50%;
  border:2px solid var(--border); font-size:18px; color:var(--indigo);
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
.testi-nav button:hover { background:var(--indigo); color:var(--white); border-color:var(--indigo); }

/* ═══════════ CONTACT STRIP ═══════════ */
#contact-strip { background:var(--off-white); padding:80px 0; }
.cstrip-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.cstrip-item {
  display:flex; align-items:flex-start; gap:18px;
  padding:28px 24px; border-radius:18px;
  background:var(--white); border:1.5px solid var(--border);
  transition:var(--transition);
}
.cstrip-item:hover { border-color:var(--indigo); box-shadow:var(--shadow-sm); transform:translateY(-4px); }
.cstrip-icon {
  width:52px; height:52px; border-radius:14px; flex-shrink:0;
  background:var(--indigo-soft); color:var(--indigo);
  display:flex; align-items:center; justify-content:center; font-size:22px;
  transition:var(--transition);
}
.cstrip-item:hover .cstrip-icon { background:var(--indigo); color:var(--white); }
.cstrip-item h4 { font-size:14px; font-weight:700; color:var(--charcoal); margin-bottom:6px; }
.cstrip-item p, .cstrip-item a {
  font-size:14px; color:var(--grey); line-height:1.6;
  transition:color var(--transition);
}
.cstrip-item a:hover { color:var(--indigo); }

/* ═══════════ CTA BANNER ═══════════ */
#cta-section { padding:120px 0; position:relative; overflow:hidden; text-align:center; }
.cta-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.cta-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(26,20,40,0.92) 0%,rgba(61,31,142,0.82) 100%);
}
.cta-particles { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.cp {
  position:absolute; border-radius:50%;
  background:var(--amber); opacity:0.35;
  animation:cpFloat 7s ease-in-out infinite;
}
@keyframes cpFloat {
  0%,100% { transform:translateY(0); opacity:0.35; }
  50%      { transform:translateY(-45px); opacity:0.75; }
}
.cta-body { position:relative; z-index:2; }
.cta-body .cta-tag {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--amber);
  border:1px solid rgba(245,166,35,0.32); padding:7px 20px; border-radius:50px;
  margin-bottom:22px;
}
#cta-section h2 {
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,4vw,52px); font-weight:800;
  color:var(--white); margin-bottom:14px; line-height:1.2;
}
#cta-section h2 em { color:var(--amber); font-style:italic; }
.cta-body p { font-size:16px; color:rgba(255,255,255,0.68); margin-bottom:40px; }
.cta-btns { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.btn-cta-primary {
  background:var(--amber); color:var(--charcoal);
  padding:14px 38px; border-radius:50px; font-size:15px; font-weight:700;
  transition:var(--transition);
}
.btn-cta-primary:hover { background:var(--amber-dark); transform:translateY(-3px); box-shadow:0 10px 32px rgba(245,166,35,0.45); }
.btn-cta-ghost {
  border:2px solid rgba(255,255,255,0.42); color:var(--white);
  padding:12px 36px; border-radius:50px; font-size:15px; font-weight:600;
  transition:var(--transition);
}
.btn-cta-ghost:hover { background:rgba(255,255,255,0.10); border-color:rgba(255,255,255,0.80); transform:translateY(-3px); }

/* ═══════════ FOOTER ═══════════ */
#footer { background:#f4f2ff; border-top:1px solid #e0d9f5; }
.footer-top { padding:72px 0 56px; }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; }
.fg-brand p { font-size:14px; line-height:1.8; color:#6b6080; margin:20px 0 24px; }
.footer-socials { display:flex; gap:10px; }
.footer-socials a {
  width:38px; height:38px; border-radius:8px;
  background:rgba(61,31,142,0.08); border:1px solid rgba(61,31,142,0.15);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; color:var(--indigo);
  transition:var(--transition);
}
.footer-socials a:hover { background:var(--indigo); color:var(--white); border-color:var(--indigo); transform:translateY(-3px); }
.fg-col h4 {
  font-size:15px; font-weight:700; color:var(--charcoal);
  margin-bottom:20px; padding-bottom:12px; position:relative;
}
.fg-col h4::after {
  content:''; position:absolute; bottom:0; left:0;
  width:30px; height:2px;
  background:linear-gradient(90deg,var(--indigo),var(--amber)); border-radius:2px;
}
.fg-col ul li { margin-bottom:10px; }
.fg-col ul li a {
  font-size:14px; color:#6b6080;
  display:flex; align-items:center; gap:6px; transition:var(--transition);
}
.fg-col ul li a::before { content:'›'; color:var(--amber); font-size:16px; }
.fg-col ul li a:hover { color:var(--indigo); padding-left:4px; }
.footer-bottom {
  border-top:1px solid #ddd8f0;
  padding:20px 0; text-align:center;
  font-size:13px; color:#9990b0;
  background:#eeebfa;
}
.footer-bottom span { color:var(--indigo); }

/* ═══════════ FLOATING WIDGETS ═══════════ */
.float-widgets {
  position:fixed; right:16px; bottom:80px; z-index:999;
  display:flex; flex-direction:column; gap:10px;
}
.fw-google, .fw-whatsapp {
  width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 18px rgba(0,0,0,0.22);
  transition:var(--transition);
}
.fw-google { background:var(--white); }
.fw-whatsapp { background:#25d366; color:var(--white); }
.fw-google:hover, .fw-whatsapp:hover { transform:scale(1.12); box-shadow:0 6px 24px rgba(0,0,0,0.28); }
.call-float {
  position:fixed; left:16px; bottom:24px; z-index:999;
  display:flex; align-items:center; gap:8px;
  background:var(--white); border:2px solid var(--indigo);
  border-radius:50px; padding:10px 22px;
  font-size:14px; font-weight:600; color:var(--indigo);
  box-shadow:var(--shadow-sm); transition:var(--transition);
}
.call-float:hover { background:var(--indigo); color:var(--white); }
.cf-pulse {
  width:9px; height:9px; border-radius:50%;
  background:var(--indigo); animation:badgePulse 1.8s infinite;
}

/* ═══════════ LIGHTBOX ═══════════ */
#lightbox {
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,0.94); backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center;
}
#lightbox.active { display:flex; }
.lb-wrap { position:relative; max-width:90vw; max-height:90vh; }
#lb-img  { max-width:90vw; max-height:85vh; border-radius:12px; object-fit:contain; }
#lb-close {
  position:absolute; top:-40px; right:0;
  background:none; color:rgba(255,255,255,0.70); font-size:24px;
  transition:color 0.2s;
}
#lb-close:hover { color:var(--amber); }
#lb-prev, #lb-next {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(255,255,255,0.10); border:1px solid rgba(255,255,255,0.20);
  color:var(--white); width:46px; height:46px; border-radius:50%;
  font-size:20px; display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
#lb-prev { left:-58px; }
#lb-next { right:-58px; }
#lb-prev:hover, #lb-next:hover { background:var(--indigo); border-color:var(--indigo); }

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width:1100px) {
  #hero { grid-template-columns:1fr 1fr; }
  .hs-left-inner { padding:48px 36px; }
  .abt-cards { grid-template-columns:repeat(2,1fr); }
  .projects-grid { grid-template-columns:repeat(2,1fr); }
  .projects-grid-7 { grid-template-columns:repeat(2,1fr); }
  .proj-card-wide { grid-column:span 1; }
  .gallery-mosaic { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gm-big  { grid-column:span 2; height:260px; }
  .gm-tall { height:220px; }
  .gm-col  { display:contents; }
  .gm-item { height:220px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
}

@media (max-width:900px) {
  section { padding:72px 0; }
  #hero { grid-template-columns:1fr; grid-template-rows:1fr 1fr; height:auto; min-height:auto; }
  .hs-left { min-height:480px; }
  .hs-right { height:360px; }
  .hs-left-inner { padding:52px 36px; }
  .services-grid { grid-template-columns:1fr 1fr; }
  .cstrip-grid { grid-template-columns:1fr; }
  .testi-card { flex:0 0 calc(50% - 10px); }
}

@media (max-width:700px) {
  .nav-links {
    display:none; flex-direction:column; gap:4px;
    position:fixed; top:72px; left:0; right:0;
    background:rgba(255,255,255,0.98); backdrop-filter:blur(14px);
    padding:20px 24px 28px;
    border-bottom:1px solid var(--border);
    box-shadow:0 10px 32px rgba(0,0,0,0.10);
    z-index:999;
  }
  .nav-links.open { display:flex; }
  .nav-links a { padding:10px 14px; border-radius:10px; }
  .nav-links .nav-cta { margin-top:8px; justify-content:center; }
  .hamburger { display:flex; }
  #hero { margin-top:72px; }
  .hs-left { min-height:420px; }
  .hs-right { height:280px; }
  .hs-left-inner { padding:40px 28px; }
  .hs-title { font-size:clamp(28px,7vw,40px); }
  .hs-btns { flex-direction:column; gap:12px; margin-bottom:32px; }
  .hs-btn-primary, .hs-btn-outline { justify-content:center; }
  .hs-stat strong { font-size:22px; }
  .hs-stat-div { margin:0 14px; }
  .services-grid  { grid-template-columns:1fr; }
  .projects-grid  { grid-template-columns:1fr; }
  .projects-grid-7 { grid-template-columns:1fr; }
  .abt-cards      { grid-template-columns:1fr 1fr; }
  .abt-bottom     { flex-direction:column; padding:28px 24px; gap:24px; }
  .footer-grid    { grid-template-columns:1fr; gap:28px; }
  .gallery-mosaic { display:flex; flex-direction:column; }
  .gm-item        { height:200px; }
  .stats-inner    { margin:0 12px; }
  .testi-card     { flex:0 0 100%; padding:24px 20px; }
  #lb-prev { left:-44px; }
  #lb-next { right:-44px; }
}

@media (max-width:480px) {
  section { padding:60px 0; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .hs-stats { gap:0; }
}


/* ═══════════ PROJECT DETAIL MODAL ═══════════ */
.proj-modal-overlay {
  position:fixed; inset:0; z-index:9999;
  background:rgba(15,8,32,0.82);
  backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity 0.3s ease;
}
.proj-modal-overlay.open {
  opacity:1; pointer-events:auto;
}

.proj-modal {
  background:var(--white);
  border-radius:24px;
  max-width:860px; width:100%;
  max-height:90vh;
  overflow-y:auto;
  box-shadow:0 32px 80px rgba(61,31,142,0.30);
  transform:translateY(32px) scale(0.97);
  transition:transform 0.32s cubic-bezier(.22,.68,0,1.15);
  position:relative;
  -ms-overflow-style:none; scrollbar-width:none;
}
.proj-modal::-webkit-scrollbar { display:none; }
.proj-modal-overlay.open .proj-modal {
  transform:translateY(0) scale(1);
}

/* Close button */
.pm-close {
  position:sticky; top:16px; float:right; margin:16px 16px 0 0;
  width:38px; height:38px; border-radius:50%;
  background:rgba(61,31,142,0.08); color:var(--indigo);
  font-size:18px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--transition); z-index:10;
  border:none;
  flex-shrink:0;
}
.pm-close:hover { background:var(--indigo); color:var(--white); transform:rotate(90deg); }

/* Image slider inside modal */
.pm-gallery {
  position:relative;
  height:320px;
  overflow:hidden;
  border-radius:24px 24px 0 0;
  margin-top:-54px; /* offset for close button sticky space */
  background:#f5f5f5;
}
.pm-gallery-track {
  display:flex; height:100%;
  transition:transform 0.45s cubic-bezier(.4,0,.2,1);
}
.pm-gallery-track img {
  flex:0 0 100%; width:100%; height:100%;
  object-fit:contain; display:block;
  background:#f0eff7;
}
.pm-gallery-arrow {
  position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%;
  background:rgba(255,255,255,0.22); backdrop-filter:blur(6px);
  border:1.5px solid rgba(255,255,255,0.35); color:#fff;
  font-size:16px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--transition); z-index:5;
}
.pm-gallery-arrow:hover { background:var(--amber); border-color:var(--amber); color:var(--charcoal); }
.pm-gallery-arrow.prev { left:14px; }
.pm-gallery-arrow.next { right:14px; }
.pm-gallery-dots {
  position:absolute; bottom:12px; left:50%; transform:translateX(-50%);
  display:flex; gap:6px; z-index:5;
}
.pm-gallery-dots span {
  width:7px; height:7px; border-radius:50%;
  background:rgba(255,255,255,0.45); cursor:pointer;
  transition:var(--transition);
}
.pm-gallery-dots span.active {
  background:var(--amber); transform:scale(1.4);
}

/* Badge on image */
.pm-badge {
  position:absolute; top:16px; left:16px; z-index:5;
  padding:5px 14px; border-radius:50px;
  font-size:11px; font-weight:700; letter-spacing:1px;
}
.pm-badge.ongoing { background:var(--amber); color:var(--charcoal); }
.pm-badge.completed { background:var(--indigo); color:var(--white); }

/* Modal body */
.pm-body { padding:28px 32px 32px; }

.pm-title {
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(16px,2vw,20px); font-weight:800;
  color:var(--charcoal); margin-bottom:6px;
}
.pm-location {
  font-size:13px; color:var(--grey); font-weight:500;
  margin-bottom:20px; display:flex; align-items:center; gap:6px;
}

/* Info chips */
.pm-chips {
  display:flex; flex-wrap:wrap; gap:10px; margin-bottom:22px;
}
.pm-chip {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--indigo-soft); color:var(--indigo);
  padding:7px 14px; border-radius:50px;
  font-size:12px; font-weight:600;
}

/* Description */
.pm-desc {
  font-size:14px; color:var(--grey); line-height:1.85;
  margin-bottom:24px;
  border-left:3px solid var(--amber);
  padding-left:16px;
}

/* Highlights grid */
.pm-highlights {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:10px; margin-bottom:28px;
}
.pm-highlight-item {
  display:flex; align-items:center; gap:10px;
  background:var(--off-white); border-radius:10px;
  padding:10px 14px;
  font-size:13px; color:var(--ink); font-weight:500;
}
.pm-highlight-item::before {
  content:'✓';
  width:22px; height:22px; border-radius:50%;
  background:var(--indigo); color:var(--white);
  font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}

/* CTA row */
.pm-ctas {
  display:flex; gap:12px; flex-wrap:wrap;
}
.pm-btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--indigo); color:var(--white);
  padding:12px 28px; border-radius:50px;
  font-size:14px; font-weight:700;
  transition:var(--transition);
  border:none; cursor:pointer;
}
.pm-btn-primary:hover { background:var(--indigo-dark); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.pm-btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  border:2px solid var(--border); color:var(--ink);
  padding:10px 26px; border-radius:50px;
  font-size:14px; font-weight:600;
  transition:var(--transition);
  background:none; cursor:pointer;
}
.pm-btn-outline:hover { border-color:var(--indigo); color:var(--indigo); }




/* Responsive */
@media (max-width:600px) {
  .pm-gallery { height:210px; margin-top:-48px; }
  .pm-body { padding:20px 18px 24px; }
  .pm-highlights { grid-template-columns:1fr; }
}


/* ===== CUSTOM CURSOR ===== */
@media (hover: hover) {
  * { cursor: none !important; }

  .cursor-dot {
    position: fixed;
    top: 0; left: 0;
    width: 8px; height: 8px;
    background: var(--indigo);
    border-radius: 50%;
    pointer-events: none;
    z-index: 99999;
    transition: opacity .3s, transform .05s linear, width .25s, height .25s, background .25s;
    will-change: transform;
  }

  .cursor-ring {
    position: fixed;
    top: 0; left: 0;
    width: 44px; height: 44px;
    border: 2px solid var(--indigo);
    border-radius: 50%;
    pointer-events: none;
    z-index: 99998;
    opacity: 0.45;
    transition: opacity .3s, width .25s, height .25s, border-color .25s, background .25s;
    will-change: transform;
  }

  .cursor-dot.cursor-hover {
    width: 14px; height: 14px;
    background: var(--amber);
    transform: translate(calc(var(--cx, 0px) - 7px), calc(var(--cy, 0px) - 7px));
  }

  .cursor-ring.cursor-hover {
    width: 60px; height: 60px;
    border-color: var(--amber);
    background: rgba(245, 166, 35, 0.08);
    opacity: 0.7;
  }
}
