/* =========================================================
   Marriage Portfolio - Itishree Lenka  ::  "Subha Sambandha"
   Theme: Traditional Indian (Cream / Maroon / Gold)
   Bilingual: English + Odia (ଓଡ଼ିଆ)
   ========================================================= */

:root {
  --color-cream: #fdf6ec;
  --color-cream-2: #f8ecd4;
  --color-gold: #c9a14a;
  --color-gold-dark: #a07a2a;
  --color-gold-light: #f1d98c;
  --color-maroon: #7a1f2b;
  --color-maroon-dark: #5a141d;
  --color-text: #3a2a14;
  --color-text-soft: #6b4a25;
  --shadow-soft: 0 10px 30px rgba(122, 31, 43, 0.12);
  --shadow-card: 0 8px 24px rgba(160, 122, 42, 0.18);

  --font-display: "Cinzel", "Playfair Display", serif;
  --font-script: "Great Vibes", cursive;
  --font-body: "Poppins", system-ui, -apple-system, "Segoe UI", sans-serif;

  --font-odia: "Noto Sans Oriya", "Noto Serif Oriya", "Kalinga", "Sakal Bharati", sans-serif;
  --font-odia-display: "Noto Serif Oriya", "Noto Sans Oriya", "Kalinga", serif;
}

/* ---------- Base ---------- */
* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background:
    radial-gradient(circle at 0% 0%, rgba(201, 161, 74, 0.10), transparent 40%),
    radial-gradient(circle at 100% 100%, rgba(122, 31, 43, 0.08), transparent 40%),
    linear-gradient(135deg, var(--color-cream) 0%, var(--color-cream-2) 100%);
  min-height: 100vh;
  line-height: 1.6;
}

/* Lock scroll while splash is active */
body.splash-active {
  overflow: hidden;
}

/* ---------- Odia language overrides ---------- */
html[lang="or"] body,
html[lang="or"] .quick-pill,
html[lang="or"] .detail-list .label,
html[lang="or"] .detail-list .value,
html[lang="or"] .contact-label,
html[lang="or"] .contact-value,
html[lang="or"] .expectations-text,
html[lang="or"] .profile-tagline {
  font-family: var(--font-odia);
}

html[lang="or"] .hero-pretitle,
html[lang="or"] .hero-title,
html[lang="or"] .hero-subtitle,
html[lang="or"] .profile-name,
html[lang="or"] .name-prefix,
html[lang="or"] .detail-card-header h3,
html[lang="or"] .contact-header h3,
html[lang="or"] .expectations-title,
html[lang="or"] .blessing-text,
html[lang="or"] .footer-text,
html[lang="or"] .footer-sub {
  font-family: var(--font-odia-display);
  letter-spacing: normal !important;
}

html[lang="or"] .hero-title { text-transform: none; }

html[lang="or"] .hero-pretitle {
  font-weight: 600;
  color: var(--color-maroon-dark);
  font-size: clamp(1.2rem, 2.4vw, 1.6rem);
}

html[lang="or"] .footer-sub {
  font-size: 1.2rem;
  color: var(--color-maroon-dark);
  font-weight: 600;
}

html[lang="or"] .profile-tagline { font-style: normal; }
html[lang="or"] .blessing-text {
  font-style: normal;
  font-size: clamp(1.05rem, 1.8vw, 1.25rem);
  line-height: 1.55;
}

a { color: var(--color-maroon); text-decoration: none; }
a:hover { color: var(--color-gold-dark); }

/* =========================================================
   SPLASH / OPENING ANIMATION
   ========================================================= */

.splash {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background:
    radial-gradient(circle at center, #2a0a10 0%, #1a0408 70%, #0d0306 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.6s ease-out;
}

.splash.fade-out {
  opacity: 0;
  pointer-events: none;
}

/* Stage with Ganesha + mantra */
.splash-stage {
  position: relative;
  text-align: center;
  z-index: 5;
  color: #f1d98c;
  padding: 0 20px;
  animation: stageFadeOut 0.6s ease-in 3.4s forwards;
}

@keyframes stageFadeOut {
  to { opacity: 0; transform: scale(0.92); }
}

/* Soft golden aura behind Ganesha */
.splash-aura {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 320px;
  height: 320px;
  margin: -250px 0 0 -160px;
  border-radius: 50%;
  background: radial-gradient(
    circle,
    rgba(241, 217, 140, 0.55) 0%,
    rgba(201, 161, 74, 0.25) 40%,
    transparent 70%
  );
  animation: auraPulse 2.4s ease-in-out infinite alternate;
  filter: blur(4px);
}
@keyframes auraPulse {
  from { transform: scale(0.9); opacity: 0.7; }
  to   { transform: scale(1.15); opacity: 1; }
}

/* Ganesha medallion (large, glowing) */
.splash-ganesha {
  width: 180px;
  height: 180px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: radial-gradient(circle, #fff7e8 0%, #fde9c8 70%, #f1d98c 100%);
  border: 4px solid var(--color-gold);
  box-shadow:
    0 0 0 3px #2a0a10,
    0 0 0 6px var(--color-gold-dark),
    0 0 60px rgba(241, 217, 140, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  opacity: 0;
  transform: scale(0.4) rotate(-15deg);
  animation: ganeshaEnter 1s cubic-bezier(0.34, 1.56, 0.64, 1) 0.2s forwards;
}
.splash-ganesha img { width: 88%; height: 88%; object-fit: contain; border-radius: 50%; }

@keyframes ganeshaEnter {
  to { opacity: 1; transform: scale(1) rotate(0deg); }
}

.splash-mantra {
  font-family: var(--font-odia-display), serif;
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 600;
  margin: 0;
  color: #f1d98c;
  text-shadow: 0 0 20px rgba(241, 217, 140, 0.6);
  opacity: 0;
  transform: translateY(15px);
  animation: textRise 0.8s ease-out 1s forwards;
}

.splash-mantra-en {
  font-family: var(--font-script);
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  margin: 4px 0 18px;
  color: #fdf0c2;
  opacity: 0;
  transform: translateY(15px);
  animation: textRise 0.8s ease-out 1.4s forwards;
}

.splash-title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  letter-spacing: 6px;
  text-transform: uppercase;
  margin: 0;
  color: #fff7e8;
  text-shadow: 0 0 24px rgba(241, 217, 140, 0.7);
  opacity: 0;
  transform: translateY(15px);
  animation: textRise 0.8s ease-out 1.9s forwards;
}

.splash-subtitle {
  font-family: var(--font-script);
  font-size: clamp(1.2rem, 2.4vw, 1.8rem);
  color: var(--color-gold-light);
  margin: 6px 0 0;
  opacity: 0;
  transform: translateY(15px);
  animation: textRise 0.8s ease-out 2.3s forwards;
}

@keyframes textRise {
  to { opacity: 1; transform: translateY(0); }
}

/* Gold curtains parting */
.splash-curtain {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 50%;
  background:
    linear-gradient(
      180deg,
      #c9a14a 0%,
      #a07a2a 30%,
      #8b6620 55%,
      #a07a2a 80%,
      #c9a14a 100%
    );
  background-size: 100% 100%;
  z-index: 3;
  transition: transform 1.2s cubic-bezier(0.77, 0, 0.18, 1);
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
}

.splash-curtain::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(90deg,
      rgba(255, 247, 232, 0.18) 0px,
      rgba(255, 247, 232, 0.18) 2px,
      transparent 2px,
      transparent 14px),
    repeating-linear-gradient(180deg,
      rgba(0, 0, 0, 0.12) 0px,
      rgba(0, 0, 0, 0.12) 1px,
      transparent 1px,
      transparent 8px);
  opacity: 0.7;
}

.splash-curtain-left {
  left: 0;
  border-right: 4px solid var(--color-gold-light);
  transform: translateX(0);
}
.splash-curtain-right {
  right: 0;
  border-left: 4px solid var(--color-gold-light);
  transform: translateX(0);
}

/* Trigger curtain part */
.splash.parting .splash-curtain-left { transform: translateX(-100%); }
.splash.parting .splash-curtain-right { transform: translateX(100%); }

/* Falling petals */
.splash-petals {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}
.petal {
  position: absolute;
  top: -30px;
  width: 14px;
  height: 14px;
  background: radial-gradient(circle, #f1d98c 0%, #c9a14a 70%, #7a1f2b 100%);
  border-radius: 50% 0 50% 0;
  opacity: 0.85;
  animation: petalFall linear infinite;
}
.petal.p1  { left: 8%;  animation-duration: 5.5s; animation-delay: 0s;   }
.petal.p2  { left: 18%; animation-duration: 6.8s; animation-delay: 0.7s; width: 10px; height: 10px; }
.petal.p3  { left: 28%; animation-duration: 5.2s; animation-delay: 1.2s; }
.petal.p4  { left: 40%; animation-duration: 7.0s; animation-delay: 0.3s; width: 16px; height: 16px; }
.petal.p5  { left: 52%; animation-duration: 6.0s; animation-delay: 1.6s; }
.petal.p6  { left: 62%; animation-duration: 5.8s; animation-delay: 0.9s; width: 12px; height: 12px; }
.petal.p7  { left: 72%; animation-duration: 6.4s; animation-delay: 0.4s; }
.petal.p8  { left: 80%; animation-duration: 7.2s; animation-delay: 1.4s; width: 10px; height: 10px; }
.petal.p9  { left: 88%; animation-duration: 5.6s; animation-delay: 2.0s; }
.petal.p10 { left: 95%; animation-duration: 6.6s; animation-delay: 0.6s; width: 14px; height: 14px; }

@keyframes petalFall {
  0%   { transform: translateY(-30px) rotate(0deg);    opacity: 0; }
  10%  { opacity: 0.85; }
  100% { transform: translateY(110vh) rotate(540deg);  opacity: 0; }
}

/* Skip button */
.splash-skip {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 10;
  background: rgba(255, 247, 232, 0.12);
  border: 1px solid var(--color-gold);
  color: var(--color-gold-light);
  padding: 7px 14px;
  border-radius: 50px;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.5px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background 0.2s ease;
  opacity: 0;
  animation: textRise 0.6s ease-out 1.2s forwards;
}
.splash-skip:hover {
  background: rgba(241, 217, 140, 0.25);
  color: #fff;
}

/* ---------- Decorative ornaments ---------- */
.ornament-top,
.ornament-bottom {
  height: 14px;
  background:
    repeating-linear-gradient(
      90deg,
      var(--color-maroon) 0,
      var(--color-maroon) 14px,
      var(--color-gold) 14px,
      var(--color-gold) 28px
    );
  position: relative;
}

.ornament-top::after,
.ornament-bottom::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 4px;
  background: var(--color-gold-dark);
}
.ornament-top::after { bottom: -4px; }
.ornament-bottom::after { top: -4px; }

/* ---------- Action bar ---------- */
.action-bar {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 1000;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Language toggle */
.lang-toggle {
  display: inline-flex;
  background: #fff;
  border: 2px solid var(--color-gold);
  border-radius: 50px;
  padding: 4px;
  box-shadow: var(--shadow-soft);
}

.lang-btn {
  border: none;
  background: transparent;
  color: var(--color-maroon-dark);
  padding: 6px 14px;
  border-radius: 50px;
  font-weight: 600;
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease;
  letter-spacing: 0.3px;
}
.lang-btn[data-lang="or"] {
  font-family: var(--font-odia);
  font-size: 0.95rem;
}
.lang-btn:hover { background: rgba(201, 161, 74, 0.15); }
.lang-btn.active {
  background: linear-gradient(135deg, var(--color-maroon), var(--color-maroon-dark));
  color: #fff;
  box-shadow: 0 3px 10px rgba(122, 31, 43, 0.3);
}

.btn-action {
  background: linear-gradient(135deg, var(--color-maroon), var(--color-maroon-dark));
  color: #fff;
  border: 2px solid var(--color-gold);
  border-radius: 50px;
  padding: 8px 18px;
  font-weight: 500;
  letter-spacing: 0.3px;
  box-shadow: var(--shadow-soft);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-action:hover {
  background: linear-gradient(135deg, var(--color-gold-dark), var(--color-maroon));
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(122, 31, 43, 0.25);
}
.btn-action.dropdown-toggle::after { margin-left: 6px; }

/* Download menu */
.download-menu {
  border: 2px solid var(--color-gold);
  border-radius: 12px;
  padding: 6px;
  box-shadow: var(--shadow-soft);
  min-width: 220px;
}
.download-menu .dropdown-item {
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  color: var(--color-maroon-dark);
}
.download-menu .dropdown-item i {
  color: var(--color-maroon);
  font-size: 1.1rem;
}
.download-menu .dropdown-item:hover,
.download-menu .dropdown-item:focus {
  background: linear-gradient(135deg, #fff7e8, #fde9c8);
  color: var(--color-maroon-dark);
}

/* ---------- Wrapper ---------- */
.portfolio-wrapper { padding: 50px 12px 30px; }

.portfolio-wrapper .container {
  max-width: 1080px;
  background: #fffdf8;
  border: 2px solid var(--color-gold);
  border-radius: 16px;
  padding: 40px clamp(20px, 4vw, 60px);
  box-shadow: var(--shadow-soft);
  position: relative;
}

.portfolio-wrapper .container::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(160, 122, 42, 0.5);
  border-radius: 12px;
  pointer-events: none;
}

/* ---------- Hero ---------- */
.hero-section { padding: 16px 0 24px; }

.hero-ganesha {
  width: 110px;
  height: 110px;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: radial-gradient(circle, #fff7e8 0%, #fde9c8 70%, #f1d98c 100%);
  border: 4px solid var(--color-gold);
  box-shadow:
    0 0 0 3px #fffdf8,
    0 0 0 5px var(--color-gold-dark),
    0 8px 24px rgba(160, 122, 42, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
  animation: ganeshaGlow 3s ease-in-out infinite alternate;
}

.hero-ganesha img {
  width: 90%;
  height: 90%;
  object-fit: contain;
  border-radius: 50%;
}

@keyframes ganeshaGlow {
  from { box-shadow: 0 0 0 3px #fffdf8, 0 0 0 5px var(--color-gold-dark), 0 8px 24px rgba(160, 122, 42, 0.45); }
  to   { box-shadow: 0 0 0 3px #fffdf8, 0 0 0 5px var(--color-gold-dark), 0 10px 32px rgba(201, 161, 74, 0.7); }
}

.hero-pretitle {
  font-family: var(--font-script);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  color: var(--color-maroon);
  margin: 0;
  line-height: 1;
}

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3rem);
  color: var(--color-maroon-dark);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin: 8px 0 4px;
  font-weight: 700;
}

.hero-subtitle {
  font-family: var(--font-body);
  font-style: italic;
  font-size: clamp(0.95rem, 1.6vw, 1.1rem);
  color: var(--color-text-soft);
  margin: 4px 0 0;
}

/* ---------- Divider ---------- */
.divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 12px auto;
}
.divider::before,
.divider::after {
  content: "";
  height: 1px;
  width: clamp(60px, 18vw, 140px);
  background: linear-gradient(90deg, transparent, var(--color-gold-dark), transparent);
}
.divider-icon { color: var(--color-gold-dark); font-size: 1.2rem; }

/* ---------- Profile Hero ---------- */
.profile-hero {
  margin-top: 28px;
  padding: 26px clamp(10px, 2.5vw, 30px);
  background: linear-gradient(135deg, #fff7e8, #fdf0d8);
  border-radius: 14px;
  border: 1px solid var(--color-gold-light);
}

.photo-frame {
  position: relative;
  display: inline-block;
  padding: 12px;
  background: linear-gradient(135deg, var(--color-gold), var(--color-gold-dark));
  border-radius: 14px;
  box-shadow: var(--shadow-card);
}

.photo-frame-inner {
  background: #fff;
  padding: 6px;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}

/* =========================================================
   PHOTO SLIDER (right-to-left auto rotate)
   ========================================================= */
.photo-slider {
  position: relative;
  width: 280px;
  height: 360px;
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(160, 122, 42, 0.3);
}

.photo-slide {
  position: absolute;
  inset: 0;
  transform: translateX(100%);
  transition: transform 0.9s cubic-bezier(0.77, 0, 0.18, 1), opacity 0.9s ease;
  opacity: 0;
}
.photo-slide.active {
  transform: translateX(0);
  opacity: 1;
  z-index: 2;
}
.photo-slide.leaving {
  transform: translateX(-100%);
  opacity: 1;
  z-index: 1;
}

.photo-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.profile-photo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Slider dots */
.photo-dots {
  position: absolute;
  bottom: 10px;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  gap: 8px;
  z-index: 3;
}
.photo-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: 2px solid #fff;
  background: rgba(255, 255, 255, 0.4);
  padding: 0;
  cursor: pointer;
  transition: background 0.3s ease, transform 0.3s ease;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.photo-dot.active {
  background: var(--color-gold);
  transform: scale(1.3);
}

@media (max-width: 575.98px) {
  .photo-frame {
    display: block;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  .photo-slider {
    width: min(75vw, 280px);
    height: calc(min(75vw, 280px) * 4 / 3);
    max-height: 360px;
    aspect-ratio: 3/4;
  }
}

/* Decorative photo corners */
.photo-corner {
  position: absolute;
  width: 22px;
  height: 22px;
  border: 3px solid var(--color-maroon);
}
.photo-corner-tl { top: -4px; left: -4px; border-right: none; border-bottom: none; border-top-left-radius: 6px; }
.photo-corner-tr { top: -4px; right: -4px; border-left: none; border-bottom: none; border-top-right-radius: 6px; }
.photo-corner-bl { bottom: -4px; left: -4px; border-right: none; border-top: none; border-bottom-left-radius: 6px; }
.photo-corner-br { bottom: -4px; right: -4px; border-left: none; border-top: none; border-bottom-right-radius: 6px; }

/* Name block */
.name-prefix {
  font-family: var(--font-script);
  font-size: clamp(1.3rem, 2.2vw, 1.7rem);
  color: var(--color-gold-dark);
  margin: 0;
  line-height: 1;
}
.profile-name {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3rem);
  color: var(--color-maroon-dark);
  margin: 6px 0 8px;
  font-weight: 700;
  letter-spacing: 1px;
}
.name-underline {
  width: 120px;
  height: 3px;
  background: linear-gradient(90deg, var(--color-gold), var(--color-gold-dark));
  border-radius: 2px;
  margin: 0 auto;
}
@media (min-width: 992px) { .name-underline { margin: 0; } }
.profile-tagline {
  font-style: italic;
  color: var(--color-text-soft);
  margin-top: 14px;
  font-size: 1.02rem;
}

/* Quick info pills */
.quick-pill {
  background: #fff;
  border: 1px solid var(--color-gold);
  color: var(--color-maroon-dark);
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  box-shadow: 0 2px 6px rgba(160, 122, 42, 0.15);
}
.quick-pill i { color: var(--color-gold-dark); }

/* ---------- Detail Cards ---------- */
.detail-card {
  background: #fff;
  border: 1px solid var(--color-gold-light);
  border-radius: 14px;
  padding: 26px clamp(18px, 3vw, 30px);
  box-shadow: 0 6px 18px rgba(160, 122, 42, 0.10);
  position: relative;
  overflow: hidden;
}

.detail-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-gold), var(--color-maroon), var(--color-gold));
}

.detail-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 1px dashed var(--color-gold-light);
  padding-bottom: 14px;
  margin-bottom: 18px;
}

.detail-card-header h3 {
  font-family: var(--font-display);
  font-size: 1.4rem;
  margin: 0;
  color: var(--color-maroon-dark);
  font-weight: 600;
  letter-spacing: 0.5px;
}

.detail-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-maroon), var(--color-maroon-dark));
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(122, 31, 43, 0.3);
}

.detail-list { list-style: none; padding: 0; margin: 0; }

.detail-list li {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px dotted rgba(160, 122, 42, 0.3);
}
.detail-list li:last-child { border-bottom: none; }

.detail-list .label {
  color: var(--color-text-soft);
  font-weight: 500;
  font-size: 0.95rem;
  min-width: 140px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.detail-list .label i { color: var(--color-gold-dark); }

.detail-list .value {
  color: var(--color-text);
  font-weight: 600;
  text-align: right;
  font-size: 0.98rem;
}

/* ---------- Expectations block ---------- */
.expectations-block {
  margin-top: 22px;
  padding: 18px;
  background: linear-gradient(135deg, #fff7e8, #fde9c8);
  border-radius: 10px;
  border-left: 4px solid var(--color-maroon);
}
.expectations-title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--color-maroon-dark);
  margin: 0 0 8px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
}
.expectations-title i { color: var(--color-maroon); }
.expectations-text {
  margin: 0;
  color: var(--color-text);
  font-size: 0.95rem;
  line-height: 1.65;
}

/* ---------- Contact card ---------- */
.contact-card {
  margin-top: 28px;
  background: linear-gradient(135deg, var(--color-maroon), var(--color-maroon-dark));
  color: #fff7e8;
  border-radius: 14px;
  padding: 30px clamp(20px, 3vw, 36px);
  box-shadow: var(--shadow-soft);
  position: relative;
  overflow: hidden;
}
.contact-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(241, 217, 140, 0.45);
  border-radius: 10px;
  pointer-events: none;
}

.contact-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.contact-header h3 {
  font-family: var(--font-display);
  margin: 0;
  font-size: 1.5rem;
  color: #fff;
  letter-spacing: 0.5px;
}
.contact-header .detail-card-icon {
  background: linear-gradient(135deg, var(--color-gold), var(--color-gold-dark));
  color: #fff;
}

.contact-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 16px;
}
.contact-item:last-child { margin-bottom: 0; }

.contact-icon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  border-radius: 50%;
  background: rgba(255, 247, 232, 0.15);
  border: 1px solid var(--color-gold-light);
  color: var(--color-gold-light);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-label {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-gold-light);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.contact-value {
  margin: 2px 0 0;
  font-size: 1rem;
  color: #fff;
  font-weight: 500;
}
.contact-value a { color: #fff; border-bottom: 1px dashed var(--color-gold-light); }
.contact-value a:hover { color: var(--color-gold-light); }

.blessing-box {
  background: rgba(255, 247, 232, 0.08);
  border: 1px solid var(--color-gold-light);
  border-radius: 12px;
  padding: 24px 18px;
  font-family: var(--font-script);
  position: relative;
}
.blessing-flower { color: var(--color-gold-light); font-size: 1.4rem; }
.blessing-text {
  margin: 8px 0;
  color: #fff;
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
  line-height: 1.4;
}

/* ---------- Footer ---------- */
.portfolio-footer { margin-top: 36px; padding-top: 14px; }
.footer-text {
  font-family: var(--font-display);
  color: var(--color-maroon-dark);
  font-size: 1.05rem;
  margin: 6px 0;
  letter-spacing: 0.5px;
}
.footer-sub {
  font-family: var(--font-script);
  font-size: 1.4rem;
  color: var(--color-gold-dark);
  margin: 0;
}

/* ---------- Responsive tweaks ---------- */
@media (max-width: 767.98px) {
  .action-bar {
    top: auto;
    bottom: 16px;
    right: 16px;
    flex-direction: column;
    align-items: flex-end;
  }
  .lang-toggle { padding: 3px; }
  .lang-btn { padding: 5px 10px; font-size: 0.8rem; }
  .btn-action span { display: none; }
  .btn-action { padding: 10px 12px; }
  .splash-ganesha { width: 130px; height: 130px; }
}

@media (max-width: 575.98px) {
  .portfolio-wrapper { padding: 24px 8px; }
  .portfolio-wrapper .container { padding: 24px 16px; }
  .detail-list li { flex-direction: column; }
  .detail-list .value { text-align: left; }
  .detail-list .label { min-width: 0; }
  .hero-ganesha { width: 90px; height: 90px; }
}

/* ---------- Print styles ---------- */
@media print {
  @page {
    size: A4;
    margin: 12mm;
  }

  html, body { background: #fff !important; }
  body { color: #000; }

  .no-print, .splash, .photo-dots { display: none !important; }

  .ornament-top, .ornament-bottom { height: 8px; }

  .portfolio-wrapper { padding: 0; }

  .portfolio-wrapper .container {
    box-shadow: none;
    border: 2px solid var(--color-gold-dark);
    padding: 22px 24px;
    max-width: 100%;
  }

  .detail-card,
  .contact-card,
  .profile-hero {
    box-shadow: none !important;
    page-break-inside: avoid;
    break-inside: avoid;
  }

  .contact-card { color: #fff7e8 !important; }

  .hero-ganesha { animation: none !important; }

  /* In print, only show the active photo (no slider transitions) */
  .photo-slide {
    transition: none !important;
    transform: none !important;
    opacity: 0 !important;
    position: absolute !important;
  }
  .photo-slide.active {
    opacity: 1 !important;
    position: relative !important;
  }

  a { color: inherit; text-decoration: none; }
}
