/* ═══════════════════════════════════════════════════
   MK PhotoFactory  ·  Black × Cyan · Editorial Luxury
   ═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=DM+Sans:wght@200;300;400;500&display=swap');

:root {
  /* Palette */
  --cyan:      #ebdac4;
  --cyan-dim:  rgba(0,229,204,0.12);
  --cyan-glow: rgba(0,229,204,0.25);
  --black:     #080808;
  --black2:    #0e0e0e;
  --dark:      #0f0d0b;
  --card:      #111111;
  --line:      rgba(255,255,255,0.07);
  --line-c:    rgba(0,229,204,0.18);
  --white:     #ffffff;
  --off:       #f8f6f1;
  --muted:     rgba(255,255,255,0.42);

  /* Type */
  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;

  /* Motion */
  --ease:  cubic-bezier(0.22, 1, 0.36, 1);
  --fast:  0.28s var(--ease);
  --slow:  0.6s var(--ease);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background: var(--black);
  color: var(--white);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display:block; max-width:100%; height:auto; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
.container { max-width:1280px; margin:0 auto; padding:0 44px; }

/* ── NAVBAR ── */
#navbar {
  position: fixed; top:0; left:0; right:0; z-index:900;
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 52px;
  height: 68px;
  background: transparent;
  transition: background var(--fast), box-shadow var(--fast);
}
#navbar.scrolled {
  background: rgba(8,8,8,0.96);
  backdrop-filter: blur(18px) saturate(160%);
  box-shadow: 0 1px 0 var(--line-c);
}
.nav-logo a { display:flex; align-items:center; }
.nav-logo img {
  height: 40px; width:auto; object-fit:contain;
  transition: height var(--fast);
  filter: drop-shadow(0 0 10px rgba(0,229,204,0.2));
}
.nav-logo-fallback {
  font-family: var(--serif); font-size:1.3rem; letter-spacing:.02em;
  display:none;
}
.nav-logo-fallback em { color:var(--cyan); font-style:normal; }

.nav-menu { display:flex; align-items:center; gap:8px; }
.nav-menu a {
  font-size:.68rem; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted);
  padding: 6px 14px; position:relative;
  transition: color var(--fast);
}
.nav-menu a::after {
  content:''; position:absolute; bottom:0; left:14px; right:14px;
  height:1px; background:var(--cyan);
  transform:scaleX(0); transform-origin:left;
  transition: transform var(--fast);
}
.nav-menu a:hover, .nav-menu a.active { color:var(--white); }
.nav-menu a:hover::after, .nav-menu a.active::after { transform:scaleX(1); }
.nav-cta {
  margin-left:16px;
  font-size:.65rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--black);
  background:var(--cyan); padding:9px 22px;
  transition: all var(--fast);
}
.nav-cta:hover { background:transparent; color:var(--cyan); outline:1px solid var(--cyan); }

.nav-burger { display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:901; }
.nav-burger span { display:block; width:24px; height:1.5px; background:var(--white); transition:var(--fast); }

/* ── HERO ── */
.hero {
  position:relative;
  height: 100vh; min-height:600px; max-height:1000px;
  display:flex; align-items:center; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
}
.hero-bg img {
  width:100%; height:100%; object-fit:cover;
  object-position: center center;
  transform:scale(1.06);
  animation: heroZoom 12s ease-in-out infinite alternate;
}
.hero-bg::after {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(
    105deg,
    rgba(8,8,8,0.88) 0%,
    rgba(8,8,8,0.55) 55%,
    rgba(8,8,8,0.30) 100%
  );
}
.hero-inner {
  position:relative; z-index:2;
  padding: 0 52px;
  max-width:900px;
}
.hero-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.62rem; font-weight:500; letter-spacing:.3em;
  text-transform:uppercase; color:var(--cyan);
  margin-bottom:28px;
  animation: fadeUp .9s var(--ease) both;
}
.hero-tag::before {
  content:''; display:block; width:32px; height:1px; background:var(--cyan);
}
.hero-h1 {
  font-family: var(--serif);
  font-size: clamp(3rem, 6.5vw, 6.5rem);
  font-weight:700; line-height:1.02;
  margin-bottom:28px;
}
.hero-h1 .row1 { display:block; animation: fadeUp 1s var(--ease) .15s both; }
.hero-h1 .row2 {
  display:block; font-style:italic; color:var(--cyan);
  animation: fadeUp 1s var(--ease) .3s both;
}
.hero-h1 .row3 { display:block; animation: fadeUp 1s var(--ease) .45s both; }
.hero-sub {
  font-size:.9rem; font-weight:300; color:rgba(255,255,255,.6);
  max-width:480px; margin-bottom:44px; line-height:1.75;
  animation: fadeUp 1s var(--ease) .55s both;
}
.hero-btns {
  display:flex; gap:14px; flex-wrap:wrap;
  animation: fadeUp 1s var(--ease) .7s both;
}
.hero-scroll {
  position:absolute; right:48px; bottom:44px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  animation: fadeIn 1.5s ease 1.2s both;
}
.hero-scroll span {
  font-size:.55rem; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.3); writing-mode:vertical-rl;
}
.hero-scroll-line {
  width:1px; height:52px;
  background: linear-gradient(to bottom, var(--cyan), transparent);
  animation: scrollPulse 1.8s ease infinite;
}

/* ── TICKER ── */
.ticker {
  background:var(--cyan); overflow:hidden; padding:13px 0;
}
.ticker-track {
  display:flex; width:max-content;
  animation: marquee 30s linear infinite;
}
.ticker-track span {
  font-size:.6rem; font-weight:500; letter-spacing:.28em;
  text-transform:uppercase; color:var(--black);
  padding:0 36px; border-right:1px solid rgba(0,0,0,.14);
  white-space:nowrap;
}

/* ── SECTION LABELS & HEADINGS ── */
.eyebrow {
  font-size:.6rem; font-weight:500; letter-spacing:.32em;
  text-transform:uppercase; color:var(--cyan);
  display:flex; align-items:center; gap:10px; margin-bottom:14px;
}
.eyebrow::before { content:''; display:block; width:24px; height:1px; background:var(--cyan); }
.section-h {
  font-family: var(--serif);
  font-size: clamp(2.2rem, 4vw, 3.8rem);
  font-weight:700; line-height:1.1; color:var(--white);
}
.section-h em { font-style:italic; color:var(--cyan); }
.section-h.dark { color:var(--black); }
.section-h.dark em { color:var(--black); opacity:.65; }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sans); font-size:.68rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  padding:13px 32px; cursor:pointer; transition:all var(--fast);
  border:none;
}
.btn-c { background:var(--cyan); color:var(--black); }
.btn-c:hover { background:transparent; color:var(--cyan); outline:1px solid var(--cyan); }
.btn-o { background:transparent; color:var(--white); outline:1px solid rgba(255,255,255,.25); }
.btn-o:hover { outline-color:var(--cyan); color:var(--cyan); }
.btn-dark { background:var(--black); color:var(--cyan); outline:1px solid var(--black); }
.btn-dark:hover { background:transparent; color:var(--black); outline-color:var(--black); }
.btn-sm { padding:9px 22px; font-size:.62rem; }

/* ── ABOUT ── */
.about { padding:110px 0; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img {
  width:100%; height:580px; object-fit:cover;
  display:block;
}
.about-img-accent {
  position:absolute; bottom:-20px; right:-20px;
  width:180px; height:180px;
  border:1px solid var(--line-c);
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:4px;
  background:var(--black2);
}
.about-img-accent strong {
  font-family:var(--serif); font-size:3rem; font-weight:700;
  color:var(--cyan); line-height:1;
}
.about-img-accent span {
  font-size:.58rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); text-align:center; padding:0 12px;
}
.about-text { padding-left:20px; }
.about-text p { color:var(--muted); font-size:.9rem; margin-bottom:18px; line-height:1.8; }
.about-text .btn { margin-top:10px; }

/* ── GALLERY GRID ── */
.gallery-preview { padding-bottom:110px; }
.gp-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:36px; }
.gallery-mosaic {
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:260px 260px;
  gap:5px;
}
.gm-item { position:relative; overflow:hidden; }
.gm-item img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease);
  display:block;
}
.gm-item:hover img { transform:scale(1.06); }
.gm-item .gm-label {
  position:absolute; left:0; bottom:0; right:0;
  padding:40px 18px 16px;
  background:linear-gradient(transparent,rgba(8,8,8,.85));
  font-family:var(--serif); font-style:italic;
  font-size:1.05rem; color:var(--cyan);
  opacity:0; transform:translateY(8px);
  transition:all .4s var(--ease);
}
.gm-item:hover .gm-label { opacity:1; transform:translateY(0); }
.gm-a { grid-column:span 5; grid-row:span 2; }
.gm-b { grid-column:span 4; }
.gm-c { grid-column:span 3; }
.gm-d { grid-column:span 3; }
.gm-e { grid-column:span 4; }

/* ── PACKAGES ── */
.packages-section {
  background:var(--off);
  padding:110px 0;
}
.pkg-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.pkg-card {
  background:var(--white);
  padding:44px 36px;
  position:relative;
  transition:transform var(--fast), box-shadow var(--fast);
  border-top:3px solid transparent;
}
.pkg-card:hover { transform:translateY(-5px); box-shadow:0 20px 60px rgba(0,0,0,.12); border-top-color:var(--cyan); }
.pkg-card.featured { background:var(--black); border-top:3px solid var(--cyan); }
.pkg-star {
  position:absolute; top:20px; right:20px;
  background:var(--cyan); color:var(--black);
  font-size:.55rem; font-weight:700; letter-spacing:.15em;
  text-transform:uppercase; padding:4px 12px;
}
.pkg-ico { font-size:2rem; margin-bottom:18px; }
.pkg-card h3 {
  font-family:var(--serif); font-size:1.6rem; font-weight:700;
  margin-bottom:10px; color:var(--black);
}
.pkg-card.featured h3 { color:var(--white); }
.pkg-rate {
  font-size:.72rem; color:#888; margin-bottom:22px;
}
.pkg-rate strong {
  font-family:var(--serif); font-size:2.2rem; font-weight:700;
  color:var(--black); letter-spacing:-.02em;
}
.pkg-rate .sym { font-size:1.3rem; vertical-align:top; margin-top:6px; display:inline-block; }
.pkg-card.featured .pkg-rate { color:rgba(255,255,255,.5); }
.pkg-card.featured .pkg-rate strong { color:var(--cyan); }
.pkg-card ul { margin-bottom:32px; }
.pkg-card ul li {
  font-size:.8rem; color:#555;
  padding:9px 0; border-bottom:1px solid #eee;
  display:flex; align-items:center; gap:9px;
}
.pkg-card.featured ul li { color:rgba(255,255,255,.55); border-bottom-color:rgba(255,255,255,.08); }
.pkg-card ul li::before { content:'—'; color:var(--cyan); font-size:.7rem; flex-shrink:0; }
.pkg-cta-row { text-align:center; margin-top:52px; }
.pkg-cta-row .btn-dark { background:var(--black); color:var(--cyan); }
.pkg-cta-row .btn-dark:hover { background:transparent; outline-color:var(--black); color:var(--black); }

/* ── TESTIMONIALS ── */
.testimonials { padding:110px 0; background:var(--black2); }
.t-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:52px; }
.t-card {
  background:var(--card); padding:40px 32px;
  border-left:1px solid var(--line);
  transition:background var(--fast), border-color var(--fast);
}
.t-card:hover { background:rgba(0,229,204,.04); border-left-color:var(--cyan); }
.t-card:first-child { border-left:none; }
.t-stars { color:var(--cyan); letter-spacing:4px; font-size:.75rem; margin-bottom:18px; }
.t-quote {
  font-family:var(--serif); font-style:italic;
  font-size:1rem; color:rgba(255,255,255,.72);
  line-height:1.8; margin-bottom:26px;
}
.t-author { display:flex; align-items:center; gap:14px; }
.t-av {
  width:40px; height:40px; border-radius:50%;
  background:var(--cyan); color:var(--black);
  font-weight:700; font-size:.9rem; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.t-name { font-size:.82rem; font-weight:500; display:block; }
.t-role { font-size:.68rem; color:var(--muted); display:block; margin-top:2px; }

/* ── REEL (scrolling strip) ── */
.reel { overflow:hidden; padding:0; background:var(--dark); min-height:244px; }
.reel-track {
  display:flex; gap:4px; width:max-content;
  animation: marquee 50s linear infinite;
  animation-play-state: paused;
}
.reel-track img {
  width:340px; height:240px; object-fit:cover; flex-shrink:0;
  filter:grayscale(20%) brightness(.9);
  transition:filter .4s, opacity .4s;
  background:var(--charcoal);
  opacity:0;
}
.reel-track img.loaded { opacity:1; }
.reel-track img:hover { filter:none; }

/* ── CTA BANNER ── */
.cta-band {
  background:var(--cyan);
  padding:90px 0; text-align:center;
}
.cta-band h2 {
  font-family:var(--serif); font-size:clamp(2.2rem,4vw,4rem);
  font-weight:700; color:var(--black); margin-bottom:14px;
}
.cta-band h2 em { font-style:italic; opacity:.7; }
.cta-band p { font-size:.9rem; color:rgba(0,0,0,.6); margin-bottom:36px; }

/* ── FOOTER ── */
footer {
  background:var(--black2);
  border-top:1px solid var(--line-c);
  padding:72px 0 0;
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr;
  gap:56px; margin-bottom:56px;
}
.footer-logo img {
  height:44px; width:auto; object-fit:contain; margin-bottom:18px;
}
.footer-logo-fb { display:none; font-family:var(--serif); font-size:1.2rem; margin-bottom:18px; }
.footer-logo-fb em { color:var(--cyan); font-style:normal; }
.footer-brand p { font-size:.78rem; color:var(--muted); line-height:1.8; max-width:230px; margin-bottom:24px; }
.footer-social { display:flex; gap:8px; }
.footer-social a {
  width:36px; height:36px; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-size:.62rem; font-weight:600; color:var(--muted);
  transition:all var(--fast);
}
.footer-social a:hover { border-color:var(--cyan); color:var(--cyan); }
.footer-col h5 {
  font-size:.58rem; font-weight:500; letter-spacing:.28em;
  text-transform:uppercase; color:var(--cyan); margin-bottom:20px;
}
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { font-size:.78rem; color:var(--muted); transition:color var(--fast); }
.footer-col ul li a:hover { color:var(--white); }
.footer-col p { font-size:.78rem; color:var(--muted); margin-bottom:8px; }
.footer-bar {
  border-top:1px solid var(--line);
  padding:20px 0; text-align:center;
}
.footer-bar p { font-size:.68rem; color:rgba(255,255,255,.2); letter-spacing:.08em; }

/* ── INNER PAGE HERO ── */
.page-hero {
  height:54vh; min-height:360px;
  padding-top:68px;
  background:var(--black2);
  display:flex; align-items:flex-end;
  border-bottom:1px solid var(--line-c);
  position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 50%, var(--cyan-dim), transparent);
}
.page-hero-content { position:relative; z-index:1; padding:0 44px 52px; }
.page-hero-content .eyebrow { margin-bottom:12px; }
.page-hero-content h1 {
  font-family:var(--serif);
  font-size:clamp(2.8rem,6vw,5.5rem);
  font-weight:700; line-height:1.05;
}
.page-hero-content h1 em { color:var(--cyan); font-style:italic; }

/* ── GALLERY PAGE ── */
.gallery-pg { padding:72px 0 110px; }
.filter-row { display:flex; gap:3px; margin-bottom:44px; flex-wrap:wrap; }
.filter-btn {
  padding:8px 20px; font-family:var(--sans);
  font-size:.62rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; cursor:pointer;
  background:transparent; border:1px solid var(--line);
  color:var(--muted); transition:all var(--fast);
}
.filter-btn:hover, .filter-btn.active {
  background:var(--cyan); color:var(--black); border-color:var(--cyan);
}
.masonry { columns:3; column-gap:5px; }
.m-item { break-inside:avoid; margin-bottom:5px; overflow:hidden; }
.m-item img { width:100%; display:block; transition:transform .5s var(--ease); }
.m-item:hover img { transform:scale(1.04); }
.gallery-empty {
  text-align:center; padding:80px;
  font-family:var(--serif); font-style:italic;
  font-size:1.2rem; color:var(--muted);
  grid-column:1/-1;
}

/* ── SERVICES PAGE ── */
.services-pg { padding:72px 0 110px; }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.svc-card {
  background:var(--card); padding:44px 34px;
  border-bottom:2px solid transparent;
  transition:all var(--fast); position:relative; overflow:hidden;
}
.svc-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, var(--cyan-dim), transparent);
  opacity:0; transition:opacity var(--fast);
}
.svc-card:hover::after { opacity:1; }
.svc-card:hover { border-bottom-color:var(--cyan); }
.svc-num {
  font-family:var(--serif); font-size:3.5rem; font-weight:700;
  color:rgba(0,229,204,.08); line-height:1;
  margin-bottom:12px; display:block;
}
.svc-ico { font-size:2rem; margin-bottom:14px; position:relative; z-index:1; }
.svc-card h3 {
  font-family:var(--serif); font-size:1.5rem; font-weight:700;
  margin-bottom:12px; color:var(--white); position:relative; z-index:1;
}
.svc-card p { font-size:.82rem; color:var(--muted); line-height:1.8; position:relative; z-index:1; }

/* ── PACKAGES PAGE ── */
.packages-pg { padding:72px 0 110px; }
.pkg-cat {
  font-family:var(--serif); font-size:1.8rem; font-weight:700;
  color:var(--cyan); margin:52px 0 20px;
  padding-bottom:14px; border-bottom:1px solid var(--line-c);
  display:flex; align-items:center; gap:12px;
}
.pkg-cat:first-of-type { margin-top:0; }
.pkg-full-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-bottom:4px; }
.pkg-full-card {
  background:var(--card); border:1px solid var(--line);
  overflow:hidden; transition:all var(--fast);
}
.pkg-full-card:hover { border-color:var(--cyan); transform:translateY(-5px); box-shadow:0 20px 60px rgba(0,0,0,.4); }
.pkf-head {
  padding:28px 28px 22px;
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.02);
}
.pkf-head.cyan { background:var(--cyan); }
.pkf-head.cyan h3, .pkf-head.cyan .pkf-price { color:var(--black); }
.pkf-head h3 {
  font-family:var(--serif); font-size:1.5rem; font-weight:700;
  margin-bottom:6px; color:var(--white);
}
.pkf-price {
  font-family:var(--serif); font-size:2rem; font-weight:700;
  color:var(--cyan); line-height:1;
}
.pkf-price .sym { font-size:1.1rem; vertical-align:top; margin-top:5px; display:inline-block; }
.pkf-body { padding:26px 28px; }
.pkf-body ul li {
  font-size:.8rem; color:var(--muted);
  padding:8px 0; border-bottom:1px solid rgba(255,255,255,.05);
  display:flex; align-items:center; gap:9px;
}
.pkf-body ul li::before { content:'✓'; color:var(--cyan); font-size:.7rem; flex-shrink:0; }
.pkf-foot { padding:18px 28px; border-top:1px solid var(--line); }
.pkf-foot .btn { width:100%; justify-content:center; }
.pkg-note { text-align:center; font-style:italic; color:var(--muted); font-size:.82rem; margin-bottom:52px; }

/* ── ABOUT PAGE ── */
.about-pg { padding:72px 0 110px; }
.about-story { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; margin-bottom:90px; }
.about-story img { width:100%; height:480px; object-fit:cover; display:block; }
.about-story h2 { font-family:var(--serif); font-size:clamp(2rem,3.5vw,3.2rem); font-weight:700; margin-bottom:22px; }
.about-story p { color:var(--muted); font-size:.88rem; margin-bottom:16px; line-height:1.8; }
.stats-band { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-bottom:90px; }
.stat-b {
  background:var(--card); padding:36px; text-align:center;
  border-top:2px solid var(--cyan);
}
.stat-b strong {
  font-family:var(--serif); font-size:3rem; font-weight:700;
  color:var(--cyan); display:block; line-height:1;
}
.stat-b span { font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-top:8px; display:block; }
.vals-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.val-card { background:var(--card); padding:40px 34px; border-top:2px solid var(--line-c); transition:border-color var(--fast); }
.val-card:hover { border-top-color:var(--cyan); }
.val-ico { font-size:2rem; margin-bottom:14px; }
.val-card h3 { font-family:var(--serif); font-size:1.4rem; font-weight:700; color:var(--cyan); margin-bottom:12px; }
.val-card p { font-size:.82rem; color:var(--muted); line-height:1.8; }

/* ── CONTACT PAGE ── */
.contact-pg { padding:72px 0 110px; }
.contact-wrap { display:grid; grid-template-columns:1fr 1.7fr; gap:72px; }
.contact-aside h2 { font-family:var(--serif); font-size:clamp(1.8rem,3vw,2.8rem); font-weight:700; margin-bottom:16px; }
.contact-aside p { color:var(--muted); font-size:.88rem; margin-bottom:36px; line-height:1.8; }
.c-detail { display:flex; align-items:flex-start; gap:14px; margin-bottom:22px; }
.c-icon {
  width:42px; height:42px; border:1px solid var(--line-c);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; flex-shrink:0; color:var(--cyan);
}
.c-info strong { font-size:.6rem; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--cyan); display:block; margin-bottom:3px; }
.c-info span { font-size:.85rem; color:var(--muted); }
.contact-form-box {
  background:var(--card);
  border:1px solid var(--line);
  border-top:2px solid var(--cyan);
  padding:44px;
}
.f-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.f-group { margin-bottom:20px; }
.f-group label {
  display:block; font-size:.58rem; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--cyan); margin-bottom:8px;
}
.f-group input, .f-group select, .f-group textarea {
  width:100%; background:rgba(255,255,255,.04);
  border:1px solid var(--line); color:var(--white);
  font-family:var(--sans); font-size:.83rem; font-weight:300;
  padding:12px 15px; outline:none; transition:border-color var(--fast);
  appearance:none;
}
.f-group input:focus, .f-group select:focus, .f-group textarea:focus {
  border-color:var(--cyan);
  background:rgba(0,229,204,.03);
}
.f-group select option { background:var(--dark); }
.f-group textarea { resize:vertical; min-height:120px; }
.f-submit {
  width:100%; padding:15px;
  background:var(--cyan); color:var(--black);
  border:2px solid var(--cyan);
  font-family:var(--sans); font-size:.7rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  cursor:pointer; transition:all var(--fast);
}
.f-submit:hover { background:transparent; color:var(--cyan); }
.ty-box {
  display:none; text-align:center; padding:60px 40px;
  background:var(--card); border:1px solid var(--line);
  border-top:2px solid var(--cyan);
}
.ty-box.show { display:block; }
.ty-ico { font-size:3rem; margin-bottom:18px; }
.ty-box h3 { font-family:var(--serif); font-size:2.4rem; color:var(--cyan); margin-bottom:12px; }
.ty-box p { color:var(--muted); font-size:.88rem; }

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(28px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes heroZoom { from{transform:scale(1.06)} to{transform:scale(1)} }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes scrollPulse {
  0%   { transform:scaleY(0); transform-origin:top; }
  50%  { transform:scaleY(1); transform-origin:top; }
  50.01% { transform:scaleY(1); transform-origin:bottom; }
  100% { transform:scaleY(0); transform-origin:bottom; }
}
.reveal { opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity:1; transform:translateY(0); }

/* ── RESPONSIVE ── */
@media (max-width:1100px) {
  .pkg-grid, .pkg-full-grid, .svc-grid, .t-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:40px; }
  .gallery-mosaic { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gm-a,.gm-b,.gm-c,.gm-d,.gm-e { grid-column:span 1; grid-row:auto; }
  .masonry { columns:2; }
  .about-grid, .contact-wrap, .about-story { grid-template-columns:1fr; gap:44px; }
  .about-img { height:420px; }
  .stats-band { grid-template-columns:repeat(2,1fr); }
  .vals-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
  #navbar { padding:0 24px; }
  .nav-menu { display:none; position:fixed; inset:0; background:var(--black); flex-direction:column; justify-content:center; align-items:center; gap:28px; z-index:900; }
  .nav-menu.open { display:flex; }
  .nav-menu a { font-size:.9rem; }
  .nav-cta { display:none; }
  .nav-burger { display:flex; }
  .container { padding:0 22px; }
  .hero-inner { padding:0 24px; }
  .hero-scroll { display:none; }
  .hero { min-height:100svh; }
  .hero-bg img { object-fit: cover; object-position: 75% center; }
  .hero-bg::after {
    background: linear-gradient(
      180deg,
      rgba(8,8,8,0.75) 0%,
      rgba(8,8,8,0.45) 50%,
      rgba(8,8,8,0.65) 100%
    );
  }
  .hero-h1 { font-size: clamp(2.8rem, 12vw, 5rem); }
  .hero-sub { font-size: .82rem; max-width:100%; }
  .hero-btns { flex-direction:column; gap:12px; align-items:flex-start; }
  .hero-btns .btn { width:100%; text-align:center; }
  .pkg-grid, .t-grid, .svc-grid { grid-template-columns:1fr; }
  .f-row { grid-template-columns:1fr; }
  .masonry { columns:1; }
  .stats-band, .vals-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .pkg-full-grid { grid-template-columns:1fr; }
  .contact-form-box { padding:26px 20px; }
  .page-hero-content { padding:0 22px 40px; }
  .reel-track img { width:220px; height:160px; }
  .gallery-mosaic { grid-template-columns:1fr; grid-template-rows:auto; }
  .gm-item { min-height:220px; }
  .about-grid { grid-template-columns:1fr; }
  .pkg-full-grid { grid-template-columns:1fr; }
  .nav-social { display:none; }
  .section-h { font-size: clamp(1.6rem, 6vw, 2.4rem); }
  .pkf-head h3 { font-size:1.1rem; }
  .stat-b strong { font-size:2rem; }
}

/* ── SOCIAL ICONS ── */
.social-icon { width:18px; height:18px; fill:currentColor; display:block; flex-shrink:0; }
.footer-social a { width:38px; height:38px; border-radius:0; }
/* Nav social strip */
.nav-social {
  display: flex; align-items:center; gap:6px; margin-left:12px;
}
.nav-social a {
  width:30px; height:30px; display:flex; align-items:center; justify-content:center;
  color:var(--muted); border:1px solid var(--line); border-radius:0;
  transition:all var(--fast);
}
.nav-social a:hover { color:var(--cyan); border-color:var(--cyan); }
.nav-social .social-icon { width:14px; height:14px; }
/* WhatsApp float button */
.whatsapp-float {
  position:fixed; bottom:24px; right:24px; z-index:999;
  width:52px; height:52px; border-radius:50%;
  background:#25D366; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:transform var(--fast), box-shadow var(--fast);
}
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,0.55); }
.whatsapp-float .social-icon { width:26px; height:26px; fill:#fff; }
