:root{
  --indigo:#0E1F3B;
  --midnight:#1A2A6C;
  --gold:#D7A84A;
  --off:#F6F7FB;
  --text:#101624;
  --radius:16px;
  --shadow:0 12px 30px rgba(0,0,0,.18);
}

/* ============ BASE ============ */
*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
  color:var(--text);
  background:var(--off);
  line-height:1.65;
}
h1,h2,h3,h4{font-family:Montserrat,Inter,Arial;margin:0 0 10px 0}
a{color:var(--midnight);text-decoration:none}
a:hover{color:var(--gold)}
.container{width:min(1200px,92%);margin-inline:auto}
.section{padding:80px 0}
.btn{
  display:inline-block;
  padding:12px 22px;
  border-radius:999px;
  font-weight:700;
  transition:all .3s ease;
}
.btn.primary{
  background:var(--gold);
  color:var(--indigo);
  box-shadow:var(--shadow);
}
.btn.ghost{
  border:2px solid var(--gold);
  color:var(--gold);
}
.btn:hover{transform:translateY(-2px);opacity:.9}

/* ============ HEADER ============ */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(14,31,59,.7);
  backdrop-filter:blur(8px);
}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  color:#fff;
}
.nav .brand{display:flex;align-items:center;gap:10px;color:#fff}
.nav img{height:34px;width:auto}
.nav a{color:#fff;opacity:.9;margin-left:16px;transition:.3s}
.nav a:hover{opacity:1;color:var(--gold)}

/* ============ HERO SECTION (HOME) ============ */
.hero{
  position:relative;
  color:#fff;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  overflow:hidden;
  padding-top:60px; /* small offset for sticky header overlap */
}

/* Background layers */
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:url('assets/A_digital_painting_or_illustration_in_a_blend_of_s.png') center 15% / cover no-repeat; /* show more top */
  filter:saturate(1.05);
  z-index:-2;
}
#bg-video{
  position:absolute;
  top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 15%; /* show more top */
  z-index:-1; /* above fallback image, below overlay/content */
}
.hero::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(14,31,59,.6));
  z-index:0;
}

/* Hero content */
.hero > .inner{
  position:relative;
  z-index:1;
  padding:0 16px;
}

/* Lift content slightly on laptops/desktops so logo stays visible */
@media (min-width:981px){
  .hero > .inner{ transform:translateY(-4vh); }
  .hero{ padding-top:48px; } /* was 60px */
}

/* Mobile safe viewport units to prevent crop on mobile toolbars */
@supports (height: 100svh){
  .hero{ min-height:100svh; }
}

/* Logo — responsive size with clamp(), rounded, lifted */
.hero-logo{
  height:clamp(100px, 12vw, 160px); /* min 100px, grows with viewport, max 160px */
  width:auto;
  margin-bottom:20px;
  border-radius:24px;
  box-shadow:0 10px 30px rgba(0,0,0,0.35);
  transform:translateY(-30px);
  animation:fadeInUp 1.4s ease forwards;
}

/* Headings and text animations */
.hero h1{
  font-size:clamp(36px,6vw,64px);
  margin-top:10px;
  opacity:0;
  animation:fadeInUp 1.6s ease forwards;
  animation-delay:.3s;
}
.hero p.sub{
  opacity:0;
  font-size:clamp(16px,2.2vw,20px);
  animation:fadeInUp 1.6s ease forwards;
  animation-delay:.6s;
}
.hero .cta{
  margin-top:16px;
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  opacity:0;
  animation:fadeInUp 1.6s ease forwards;
  animation-delay:.9s;
}

/* Fade-in keyframes */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============ BOOKS ============ */
.grid-books{
  display:grid;
  gap:26px;
  grid-template-columns:repeat(4,1fr);
}
.book{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:18px;
  padding:16px;
  box-shadow:var(--shadow);
  text-align:center;
  transition:transform .3s ease;
}
.book:hover{transform:translateY(-6px)}
.book img{border-radius:12px;width:100%;height:auto}
.book h4{margin:10px 0 6px 0}
.book .actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.badge{
  display:inline-block;
  background:rgba(215,168,74,.12);
  color:#7a5a1c;
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
  font-size:.9rem;
}

/* ============ CONTACT SECTION ============ */
.contact-wrap{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:24px;
}
iframe{
  width:100%;
  height:520px;
  border:0;
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
}

/* ============ FOOTER ============ */
.footer{
  background:var(--indigo);
  color:#fff;
  padding:20px 0;
}
.footer .row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

/* ============ RESPONSIVE (global) ============ */
@media (max-width:980px){
  .grid-books{grid-template-columns:repeat(2,1fr)}
  .contact-wrap{grid-template-columns:1fr}
}
@media (max-width:640px){
  #bg-video{display:none} /* save data/battery on small screens */
  .hero{padding-top:100px}
  .hero-logo{transform:none} /* keep centered on small screens */
}

/* ============ SERVICES PAGE — MATCH HOME STYLE ============ */
.services{
  position:relative;
  color:#fff;
  min-height:100vh;
  padding:80px 0;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(14,31,59,0.95),rgba(26,42,108,0.90));
}

/* Background image layer */
.services::before{
  content:"";
  position:absolute; inset:0;
  background:url('assets/A_digital_painting_or_illustration_in_a_blend_of_s.png') center 15% / cover no-repeat; /* match home framing */
  filter:saturate(1.05) brightness(0.9);
  z-index:-2;
}

/* Optional video background on services page
   (add <video class="bg" ...> inside services.html body if you want) */
.services video.bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 15%;
  z-index:-1;
  opacity:.45; /* subdued so text is readable */
}

/* Dark overlay */
.services::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.4), rgba(14,31,59,.7));
  z-index:-1;
}

/* Services content */
.services-hero{
  position:relative;
  text-align:center;
  max-width:900px;
  margin:0 auto 28px;
  z-index:1;
  animation:fadeInUp 1.2s ease forwards;
}
.services-hero h2{
  font-size:clamp(28px,3.8vw,44px);
  margin-bottom:8px;
}
.services-hero .lead{ opacity:.95; }

/* Grids reused */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}

/* Cards on dark */
.services .card{
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius);
  padding:20px;
  box-shadow:var(--shadow);
  transition:transform .3s ease, box-shadow .3s ease;
}
.services .card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 36px rgba(0,0,0,.28);
}
.services .card h3,.services .card h4{color:#fff;}
.services .card p,.services .card li{color:#e9eef6;}

/* Packages */
.packages{margin-top:34px;}
.packages .center{text-align:center;margin-bottom:12px;}
.pack{display:flex;flex-direction:column;gap:12px;}
.pack-h{
  font-weight:800;letter-spacing:.3px;color:var(--gold);
  border-bottom:1px solid rgba(255,255,255,0.15);
  padding-bottom:8px;
}
.pack-list{margin:0;padding-left:18px;}
.pack-list li{margin:6px 0;}
.price{font-weight:800;font-size:1.1rem;color:#fff;}
.pack-featured{
  outline:2px solid var(--gold);
  box-shadow:0 12px 30px rgba(215,168,74,.2);
}

/* Process */
.process{margin-top:36px;}
.process .center{text-align:center;margin-bottom:12px;}
.step{position:relative;padding-top:18px;}
.step .num{
  position:absolute; top:-14px; left:-14px;
  background: var(--gold); color: var(--indigo);
  width:32px; height:32px; border-radius:50%;
  display:inline-grid; place-items:center; font-weight:800;
}

/* Buttons on dark */
.services .btn.primary{background:var(--gold);color:var(--indigo);}
.services .btn.ghost{border-color:var(--gold);color:var(--gold);}
nav a[href="services.html"]{color:var(--gold);font-weight:600;}

/* Responsive services grids */
@media (max-width:980px){
  .grid-3{grid-template-columns:1fr;}
  .grid-4{grid-template-columns:1fr 1fr;}
}
@media (max-width:640px){
  .grid-4{grid-template-columns:1fr;}
}

/* ===== Services Hero (full-width, video background like home) ===== */
.services-hero-block{
  position:relative;
  min-height:60vh;               /* hero height on services page */
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  color:#fff;
  padding:72px 0 56px;           /* space for sticky header + breathing room */
}

/* Background video INSIDE the hero only */
.services-hero-block > video.bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 15%;    /* match home framing */
  z-index:-2;                    /* deepest layer inside hero */
}

/* Static image fallback behind video */
.services-hero-block::before{
  content:"";
  position:absolute; inset:0;
  background:url('assets/A_digital_painting_or_illustration_in_a_blend_of_s.png') center 15% / cover no-repeat;
  filter:saturate(1.05) brightness(.9);
  z-index:-3;
}

/* Gradient overlay for readability */
.services-hero-block .overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(14,31,59,.6));
  z-index:-1;
}

/* Hero inner (text/buttons) */
.services-hero-block .inner{
  position:relative;
  z-index:1;
  padding:0 16px;
  max-width:900px;
}
.services-hero-title{
  font-size:clamp(32px, 4.4vw, 56px);
  margin:0 0 8px 0;
  animation:fadeInUp 1.2s ease forwards;
}
.services-hero-sub{
  font-size:clamp(16px, 2.1vw, 20px);
  opacity:.95;
  margin:0 0 14px 0;
  animation:fadeInUp 1.2s ease forwards;
  animation-delay:.2s;
}
.services-hero-block .btn{
  animation:fadeInUp 1.2s ease forwards;
  animation-delay:.4s;
}

/* Below-hero content keeps existing .services styles */
/* ===== HARDENED SERVICES HERO FIX ===== */
.header { z-index: 100; } /* keep header above hero */

.services-hero-block{
  position: relative;
  /* full-bleed even if nested inside a .container or wrapper */
  width: 100vw;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;

  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  overflow: hidden;
  padding: 72px 0 56px; /* space for sticky header */
  background: #0E1F3B; /* safety color while media loads */
}

/* Make sure any media inside does NOT size like inline content */
.services-hero-block video,
.services-hero-block img {
  display: block;
  max-width: none !important;
}

/* Background video spans the block */
.services-hero-block > video.bg{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 15% !important;
  z-index: -2 !important;
}

/* Static fallback image behind video */
.services-hero-block::before{
  content: "";
  position: absolute;
  inset: 0;
  background: url('assets/A_digital_painting_or_illustration_in_a_blend_of_s.png') center 15% / cover no-repeat;
  filter: saturate(1.05) brightness(.9);
  z-index: -3;
}

/* Gradient overlay above media, under text */
.services-hero-block .overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(14,31,59,.6));
  z-index: -1;
}

/* Text layer */
.services-hero-block .inner{
  position: relative;
  z-index: 1;
  max-width: 900px;
  padding: 0 16px;
}

/* Tidy title/sub spacing */
.services-hero-title{ font-size: clamp(32px, 4.4vw, 56px); margin: 0 0 8px; }
.services-hero-sub{ font-size: clamp(16px, 2.1vw, 20px); opacity: .95; margin: 0 0 14px; }

/* Mobile: prefer image fallback to save bandwidth */
@media (max-width: 640px){
  .services-hero-block { padding-top: 96px; }
  .services-hero-block > video.bg{ display: none !important; }
}
