:root{
  /* Luxury palette — ivory, cream, champagne, taupe */
  --ivory:#FDFBF7;
  --cream:#FDFBF7;         /* main bg — ivory white */
  --cream-2:#F5EDE4;       /* cream beige — secondary bg */
  --cream-3:#ECE1D0;       /* cream deeper */
  --champagne:#E6C7A1;
  --champagne-light:#F0DCC1;
  --champagne-dark:#D4B08C;
  --taupe:#CBBBA0;
  --taupe-deep:#A8987D;
  --charcoal:#2B2B2B;
  --charcoal-soft:#4A4A4A;
  --grey:#7A7A7A;
  /* Legacy variable aliases — keep so existing rules cascade */
  --teal:var(--taupe);
  --teal-deep:var(--champagne-dark);
  --teal-light:var(--taupe);
  --teal-dim:rgba(203,187,160,0.12);
  --teal-border:rgba(203,187,160,0.32);
  --peach:#F2A999;
  --peach-light:#F8C8BB;
  --peach-deep:#E58972;
  --gold:var(--champagne);
  --gold-light:var(--champagne-light);
  --ink:var(--charcoal);
  --ink-soft:var(--charcoal-soft);
  --muted:var(--grey);
  --line:rgba(43,43,43,0.10);
  --shadow-soft:0 10px 40px rgba(43,43,43,0.06);
  --shadow-lift:0 20px 60px rgba(43,43,43,0.10);
  --radius:24px;
  --radius-sm:14px;
  --arch:50% 50% 0 0 / 18% 18% 0 0;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Raleway',sans-serif;
  background:var(--cream);
  color:var(--ink);
  font-size:16px;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* Grain overlay */
body::before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:0.035;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}
.container{max-width:1240px;margin:0 auto;padding:0 48px}

/* ================= Opening Animation (Elastic Rise → Fly to Nav) ================= */
.opener{
  position:fixed;inset:0;z-index:10000;
  background:var(--cream);
  transition:background 0.7s ease;
}
.opener.fading{
  background:transparent;
  pointer-events:none;
}
.opener-wrap{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  transition:top 0.95s cubic-bezier(0.77,0,0.175,1),
             left 0.95s cubic-bezier(0.77,0,0.175,1),
             transform 0.95s cubic-bezier(0.77,0,0.175,1),
             height 0.95s cubic-bezier(0.77,0,0.175,1);
  will-change:top,left,transform,height;
  height:clamp(180px,28vw,340px);
}
.opener-wrap img{
  height:100%;
  width:auto;
  display:block;
  opacity:0;
  transform:translateY(40px) scale(0.94);
  animation:elasticRise 1.4s 0.2s forwards cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes elasticRise{
  0%{opacity:0;transform:translateY(60px) scale(0.92)}
  60%{opacity:1;transform:translateY(-8px) scale(1.02)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

/* ================= Navigation ================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px 0;
  transition:background 0.35s ease,backdrop-filter 0.35s ease,padding 0.35s ease,opacity 0.5s ease;
  backdrop-filter:blur(0);
  opacity:0;
}
.nav.visible{opacity:1}
.nav.scrolled{
  background:rgba(250,246,240,0.88);
  backdrop-filter:blur(18px) saturate(1.3);
  border-bottom:1px solid var(--line);
  padding:14px 0;
}
.nav-inner{
  max-width:1240px;margin:0 auto;padding:0 48px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  display:inline-flex;align-items:center;
  height:56px;
}
.nav-logo img{
  height:100%;
  width:auto;
  display:block;
  transition:height 0.35s ease;
}
.nav.scrolled .nav-logo{height:44px}
.nav-links{
  display:flex;gap:42px;align-items:center;
  font-size:14px;font-weight:400;
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.nav-links a{
  position:relative;
  color:var(--ink-soft);
  transition:color 0.3s;
}
.nav-links a::after{
  content:'';
  position:absolute;left:0;bottom:-6px;
  width:0;height:1px;
  background:var(--teal);
  transition:width 0.35s cubic-bezier(0.77,0,0.175,1);
}
.nav-links a:hover{color:var(--teal-deep)}
.nav-links a:hover::after{width:100%}
.nav-links a.nav-cta{
  padding:11px 24px;
  background:var(--champagne);
  color:#ffffff;
  border-radius:999px;
  font-size:13px;letter-spacing:0.06em;text-transform:uppercase;font-weight:500;
  transition:all 0.3s;
}
.nav-links a.nav-cta:hover{background:var(--champagne-dark);color:#ffffff;transform:translateY(-2px)}
.nav-links a.nav-cta::after{display:none}
.mobile-toggle{
  display:none;
  align-items:center;justify-content:center;
  width:46px;height:46px;
  font-size:26px;
  color:var(--ink);
  cursor:pointer;
  line-height:1;
  background:transparent;
  border-radius:10px;
  transition:background 0.25s;
  z-index:110;
  position:relative;
}
.mobile-toggle:hover{background:rgba(43,43,43,0.06)}
.mobile-toggle:active{background:rgba(43,43,43,0.1)}

/* Backdrop behind mobile menu */
.nav-backdrop{
  position:fixed;
  inset:0;
  background:rgba(43,43,43,0.35);
  backdrop-filter:blur(4px);
  opacity:0;
  pointer-events:none;
  transition:opacity 0.35s ease;
  z-index:90;
}
.nav-backdrop.show{
  opacity:1;
  pointer-events:auto;
}

body.menu-open{overflow:hidden}

/* Mobile menu panel */
@media (max-width:768px){
  .mobile-toggle{display:inline-flex}
  .nav{padding:18px 0}
  .nav.scrolled{padding:12px 0}
  .nav-links{
    display:flex !important;
    position:fixed;
    top:0;left:0;right:0;
    flex-direction:column;
    gap:0;
    background:var(--cream);
    padding:96px 28px 44px;
    border-bottom:1px solid var(--line);
    box-shadow:0 20px 60px rgba(43,43,43,0.12);
    transform:translateY(-105%);
    transition:transform 0.45s cubic-bezier(0.77,0,0.175,1);
    z-index:95;
    text-align:center;
    max-height:100vh;
    overflow-y:auto;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{
    padding:20px 0;
    font-size:15px;
    border-bottom:1px solid var(--line);
    text-transform:uppercase;
    letter-spacing:0.1em;
    color:var(--charcoal);
  }
  .nav-links a:last-child{border-bottom:none}
  .nav-links a::after{display:none}
  .nav-links a.nav-cta{
    margin:22px auto 0;
    padding:16px 36px;
    align-self:center;
    display:inline-block;
    border-bottom:none;
    background:var(--champagne);
    color:#ffffff;
  }
}

/* ================= Hero ================= */
.hero{
  padding:180px 0 120px;
  position:relative;
  overflow:hidden;
  min-height:100vh;
  display:flex;
  align-items:center;
}
.hero::before{
  content:'';
  position:absolute;
  top:0;left:50%;
  width:900px;height:900px;
  background:radial-gradient(circle,var(--teal-dim) 0%,transparent 70%);
  transform:translateX(-50%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:60px;
  align-items:center;
  position:relative;
  z-index:2;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:12px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:28px;
}
.hero-eyebrow::before{
  content:'';width:40px;height:1px;background:var(--gold);
}
.hero-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(54px,7.6vw,116px);
  line-height:0.96;
  font-weight:500;
  color:var(--charcoal);
  letter-spacing:-0.025em;
  margin-bottom:36px;
}
.hero-title em,
.hero-title .amp,
.hero-title .glow{
  font-style:italic;
  font-weight:400;
  color:var(--champagne-dark);
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.hero-lead{
  font-size:18px;
  color:var(--ink-soft);
  max-width:520px;
  margin-bottom:44px;
  line-height:1.75;
}
.hero-actions{
  display:flex;gap:18px;flex-wrap:wrap;align-items:center;
}
.btn-primary{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 36px;
  background:var(--champagne);
  color:#ffffff;
  border-radius:999px;
  font-size:14px;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275);
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:var(--champagne-dark);
  transform:translateY(101%);
  transition:transform 0.45s cubic-bezier(0.77,0,0.175,1);
  z-index:0;
}
.btn-primary span{position:relative;z-index:1;color:#ffffff}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(212,176,140,0.4)}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary .arrow{
  width:18px;height:18px;
  transition:transform 0.3s;
  position:relative;z-index:1;
}
.btn-primary:hover .arrow{transform:translateX(5px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 28px;
  color:var(--ink);
  font-size:14px;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  border-bottom:1px solid var(--ink);
  transition:all 0.3s;
}
.btn-ghost:hover{color:var(--teal-deep);border-color:var(--teal-deep);gap:18px}

/* Hero visual — arched frame with balloon garland */
.hero-visual{
  position:relative;
  height:540px;
  width:100%;
}
.arch-frame{
  position:absolute;
  top:0;left:50%;
  transform:translateX(-50%);
  width:100%;
  max-width:420px;
  height:100%;
  background:linear-gradient(180deg,var(--cream-2) 0%,var(--cream-3) 100%);
  border-radius:240px 240px 30px 30px;
  box-shadow:var(--shadow-lift);
  overflow:hidden;
}
.arch-frame::before{
  content:'';position:absolute;
  inset:14px;
  border:1px solid rgba(201,150,92,0.4);
  border-radius:230px 230px 20px 20px;
  pointer-events:none;
  z-index:2;
}
.arch-frame.has-photo{background:var(--cream-2)}
.arch-frame.has-photo img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.arch-label{
  position:absolute;
  bottom:30px;left:50%;
  transform:translateX(-50%);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:22px;
  color:var(--teal-deep);
  text-align:center;
  letter-spacing:0.02em;
  white-space:nowrap;
}
/* Universal balloon string */
.balloon::after,
.bg-balloon::after,
.gallery-balloon::after,
.cta-balloon::after,
.about-logo-mark .dot::after,
.footer-brand .dot::after{
  content:'';
  position:absolute;
  left:50%;
  top:100%;
  width:1px;
  height:42%;
  background:linear-gradient(180deg,rgba(43,62,58,0.5),rgba(43,62,58,0.05));
  transform:translateX(-50%);
  pointer-events:none;
}

/* Balloon garland inside arch */
.balloon{
  position:absolute;
  border-radius:50%;
  box-shadow:inset -8px -12px 18px rgba(0,0,0,0.12),0 8px 22px rgba(43,62,58,0.12);
}
.b1{top:8%;left:20%;width:72px;height:88px;background:radial-gradient(circle at 30% 30%,var(--peach-light),var(--peach));animation:float 5s ease-in-out infinite}
.b2{top:4%;left:46%;width:94px;height:112px;background:radial-gradient(circle at 30% 30%,#fff,var(--cream-3));animation:float 6s ease-in-out infinite 0.3s}
.b3{top:12%;left:64%;width:64px;height:78px;background:radial-gradient(circle at 30% 30%,var(--teal-light),var(--teal));animation:float 4.5s ease-in-out infinite 0.6s}
.b4{top:28%;left:12%;width:56px;height:68px;background:radial-gradient(circle at 30% 30%,var(--gold-light),var(--gold));animation:float 5.5s ease-in-out infinite 0.4s}
.b5{top:24%;left:72%;width:48px;height:58px;background:radial-gradient(circle at 30% 30%,#fff,var(--peach-light));animation:float 5s ease-in-out infinite 0.8s}
.b6{top:38%;left:38%;width:42px;height:52px;background:radial-gradient(circle at 30% 30%,var(--peach-light),var(--peach-deep));animation:float 6s ease-in-out infinite 1s}
.b7{top:44%;left:60%;width:38px;height:46px;background:radial-gradient(circle at 30% 30%,var(--teal-light),var(--teal-deep));animation:float 4.8s ease-in-out infinite 0.5s}

.hero-stat{
  position:absolute;
  bottom:-30px;left:-20px;
  background:var(--cream);
  padding:22px 28px;
  border-radius:18px;
  box-shadow:var(--shadow-lift);
  max-width:240px;
  border:1px solid var(--line);
}
.hero-stat-num{
  font-family:'Playfair Display',serif;
  font-size:36px;font-weight:600;
  color:var(--teal-deep);
  line-height:1;
  margin-bottom:6px;
}
.hero-stat-label{
  font-size:12px;
  color:var(--muted);
  letter-spacing:0.08em;
  text-transform:uppercase;
}

/* Floating background balloons */
.bg-balloon{
  position:absolute;
  border-radius:50%;
  opacity:0.5;
  pointer-events:none;
  z-index:1;
}
.bg-b1{top:15%;right:4%;width:30px;height:36px;background:var(--peach);animation:float 6s ease-in-out infinite}
.bg-b2{bottom:20%;left:3%;width:22px;height:26px;background:var(--teal);animation:float 5s ease-in-out infinite 0.5s}
.bg-b3{top:60%;right:8%;width:18px;height:22px;background:var(--gold);animation:float 7s ease-in-out infinite 0.8s}

/* ================= Marquee ================= */
.marquee{
  padding:36px 0;
  background:var(--ink);
  overflow:hidden;
  position:relative;
}
.marquee-track{
  display:flex;
  gap:60px;
  white-space:nowrap;
  animation:scroll-x 32s linear infinite;
  width:max-content;
}
.marquee-item{
  display:inline-flex;align-items:center;gap:60px;
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:clamp(32px,4vw,52px);
  color:var(--cream);
  font-weight:500;
}
.marquee-item::after{
  content:'';
  width:14px;height:14px;border-radius:50%;
  background:var(--peach);
  display:inline-block;
}
@keyframes scroll-x{
  to{transform:translateX(-50%)}
}

/* ================= Section base ================= */
section{position:relative}
.section{padding:140px 0;position:relative}
.section-head{
  margin-bottom:80px;
  max-width:780px;
}
.section-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:12px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:24px;
}
.section-eyebrow::before{content:'';width:40px;height:1px;background:var(--gold)}
.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(40px,5.4vw,76px);
  line-height:1.02;
  font-weight:500;
  color:var(--ink);
  letter-spacing:-0.02em;
  margin-bottom:28px;
}
.section-title em{
  font-style:italic;
  color:var(--teal-deep);
  font-weight:400;
}
.section-lead{
  font-size:18px;color:var(--ink-soft);max-width:620px;
}

/* ================= About ================= */
.about{
  background:var(--cream-2);
  border-radius:0 0 var(--arch);
  padding:140px 0 160px;
}
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:100px;
  align-items:center;
}
.about-quote{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:clamp(26px,2.6vw,36px);
  line-height:1.4;
  color:var(--teal-deep);
  padding-left:36px;
  border-left:2px solid var(--gold);
  margin-bottom:40px;
}
.about-text p{
  font-size:17px;
  color:var(--ink-soft);
  margin-bottom:22px;
  line-height:1.85;
}
.about-signature{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:24px;
  color:var(--teal-deep);
  margin-top:30px;
}
.about-visual{
  position:relative;
  display:flex;
  justify-content:center;
}
.about-arch{
  position:relative;
  width:100%;
  max-width:460px;
  background:var(--cream);
  border-radius:230px 230px 24px 24px;
  box-shadow:var(--shadow-lift);
  overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:80px 48px 64px;
  text-align:center;
  gap:40px;
}
.about-arch::before{
  content:'';position:absolute;
  inset:14px;
  border:1px solid var(--teal-border);
  border-radius:220px 220px 14px 14px;
  pointer-events:none;
}
.about-logo-mark{
  display:flex;align-items:center;justify-content:center;
  margin-bottom:30px;
  width:100%;
}
.about-logo-mark img{
  max-width:100%;
  width:auto;
  height:auto;
  max-height:220px;
  display:block;
}
.about-values{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  width:100%;
  max-width:320px;
}
.about-value{
  text-align:center;
}
.about-value-wide{
  grid-column:1 / -1;
}
.about-value-num{
  font-family:'Playfair Display',serif;
  font-size:40px;font-weight:600;font-style:italic;
  color:var(--teal-deep);
  line-height:1;
}
.about-value-label{
  font-size:11px;
  color:var(--muted);
  letter-spacing:0.1em;
  text-transform:uppercase;
  margin-top:8px;
}

/* ================= Services ================= */
.services{padding:160px 0 140px}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}
.service-card{
  position:relative;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:180px 180px 24px 24px;
  padding:60px 36px 40px;
  text-align:center;
  transition:all 0.5s cubic-bezier(0.34,1.56,0.64,1);
  overflow:hidden;
}
.service-card::before{
  content:'';
  position:absolute;
  inset:8px;
  border:1px solid transparent;
  border-radius:174px 174px 16px 16px;
  transition:border-color 0.4s;
  pointer-events:none;
}
.service-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-lift);
  border-color:var(--teal-border);
}
.service-card:hover::before{border-color:var(--teal-border)}
.service-card:hover .service-icon{transform:translateY(-8px) scale(1.08)}
.service-icon{
  width:120px;height:140px;
  margin:0 auto 30px;
  position:relative;
  transition:transform 0.5s cubic-bezier(0.34,1.56,0.64,1);
  transform-origin:center bottom;
}
.service-icon-balloon{
  position:absolute;
  left:50%;top:0;
  transform:translateX(-50%);
  width:90px;height:108px;
  border-radius:50%;
  box-shadow:inset -10px -14px 20px rgba(0,0,0,0.12),0 10px 24px rgba(43,62,58,0.12);
}
.service-icon-string{
  position:absolute;
  left:50%;top:108px;
  width:1px;height:32px;
  background:linear-gradient(180deg,rgba(43,62,58,0.5),rgba(43,62,58,0.05));
  transform:translateX(-50%);
}
.s1 .service-icon-balloon{background:radial-gradient(circle at 30% 30%,var(--peach-light),var(--peach))}
.s2 .service-icon-balloon{background:radial-gradient(circle at 30% 30%,var(--teal-light),var(--teal))}
.s3 .service-icon-balloon{background:radial-gradient(circle at 30% 30%,var(--gold-light),var(--gold))}
.s4 .service-icon-balloon{background:radial-gradient(circle at 30% 30%,#fff,var(--cream-3))}
.s5 .service-icon-balloon{background:radial-gradient(circle at 30% 30%,var(--peach-light),var(--peach-deep))}
.s6 .service-icon-balloon{background:radial-gradient(circle at 30% 30%,var(--teal-light),var(--teal-deep))}
.service-title{
  font-family:'Playfair Display',serif;
  font-size:26px;font-weight:600;
  color:var(--ink);
  margin-bottom:14px;
  letter-spacing:-0.01em;
}
.service-title em{font-style:italic;color:var(--teal-deep);font-weight:500}
.service-desc{
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.7;
  margin-bottom:24px;
}
.service-link{
  font-size:12px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--teal-deep);
  display:inline-flex;align-items:center;gap:8px;
  transition:gap 0.3s;
}
.service-link:hover{gap:14px}

/* ================= Occasions ================= */
.occasions{
  background:var(--ink);
  color:var(--cream);
  padding:160px 0;
  border-radius:var(--arch);
  position:relative;
  overflow:hidden;
}
.occasions::before{
  content:'';
  position:absolute;
  top:-200px;right:-200px;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(90,158,145,0.15) 0%,transparent 70%);
  pointer-events:none;
}
.occasions::after{
  content:'';
  position:absolute;
  bottom:-100px;left:-100px;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(242,169,153,0.12) 0%,transparent 70%);
  pointer-events:none;
}
.occasions .section-title{color:var(--cream)}
.occasions .section-title em{color:var(--peach)}
.occasions .section-lead{color:rgba(250,246,240,0.7)}
.occasions .section-eyebrow{color:var(--peach)}
.occasions .section-eyebrow::before{background:var(--peach)}
.why-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  position:relative;
  z-index:2;
}
.why-card{
  padding:48px 44px;
  border:1px solid rgba(250,246,240,0.14);
  border-radius:var(--radius);
  background:rgba(250,246,240,0.02);
  backdrop-filter:blur(4px);
  transition:all 0.5s cubic-bezier(0.34,1.56,0.64,1);
  position:relative;
  overflow:hidden;
}
.why-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(230,199,161,0.08),transparent 60%);
  opacity:0;
  transition:opacity 0.4s;
}
.why-card:hover{
  transform:translateY(-6px);
  border-color:rgba(230,199,161,0.4);
  background:rgba(230,199,161,0.05);
}
.why-card:hover::before{opacity:1}
.why-num{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:20px;
  color:var(--champagne);
  margin-bottom:28px;
  letter-spacing:0.05em;
  position:relative;
}
.why-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(28px,2.6vw,36px);
  font-weight:500;
  letter-spacing:-0.01em;
  margin-bottom:16px;
  position:relative;
}
.why-title em{
  font-style:italic;
  color:var(--champagne);
  font-weight:400;
}
.why-desc{
  font-size:15px;
  color:rgba(250,246,240,0.7);
  line-height:1.8;
  position:relative;
}

/* ================= Process ================= */
.process{padding:160px 0}
.process-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
  margin-top:20px;
  position:relative;
}
.process-grid::before{
  content:'';
  position:absolute;
  top:44px;left:8%;right:8%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--teal-border) 20%,var(--teal-border) 80%,transparent);
}
.step{
  text-align:center;
  position:relative;
}
.step-num{
  width:88px;height:88px;
  margin:0 auto 32px;
  border-radius:50%;
  background:var(--cream);
  border:1px solid var(--teal-border);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;
  font-size:32px;font-style:italic;
  color:var(--teal-deep);
  position:relative;
  z-index:2;
  transition:all 0.4s;
}
.step:hover .step-num{
  background:var(--teal-deep);
  color:var(--cream);
  transform:scale(1.08);
}
.step-title{
  font-family:'Playfair Display',serif;
  font-size:24px;font-weight:600;
  color:var(--ink);
  margin-bottom:14px;
}
.step-title em{font-style:italic;font-weight:500;color:var(--teal-deep)}
.step-desc{
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.7;
  max-width:240px;
  margin:0 auto;
}

/* ================= Gallery ================= */
.gallery{
  background:var(--cream-2);
  padding:160px 0;
  border-radius:var(--arch) var(--arch) 0 0;
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-template-rows:repeat(3,200px);
  gap:20px;
}
.gallery-item{
  position:relative;
  background:var(--cream);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:all 0.5s cubic-bezier(0.34,1.56,0.64,1);
  display:flex;align-items:center;justify-content:center;
  padding:30px;
}
.gallery-item:hover{
  transform:translateY(-6px) scale(1.02);
  box-shadow:var(--shadow-lift);
}
.gi-1,.gi-2,.gi-3,.gi-4,.gi-5,.gi-6,.gi-7,.gi-8,.gi-9,.gi-10,.gi-11,.gi-12,.gi-13,.gi-14,.gi-15,.gi-16,.gi-17,.gi-18{
  grid-column:auto !important;
  grid-row:auto !important;
  border-radius:24px !important;
}

.gi-balloons{
  position:relative;width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
}
.gi-title{
  position:absolute;
  bottom:24px;left:28px;
  font-family:'Playfair Display',serif;
  font-size:18px;font-style:italic;
  color:var(--ink);
  z-index:3;
}
.gi-1 .gi-title{font-size:26px;bottom:32px;left:36px}
.gi-tag{
  position:absolute;
  top:20px;right:20px;
  font-size:10px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gold);
  z-index:3;
}
.gallery-balloon{
  position:absolute;
  border-radius:50%;
  box-shadow:inset -6px -10px 14px rgba(0,0,0,0.12),0 6px 18px rgba(43,62,58,0.1);
}

/* Photo gallery items (used in Birthday Balloons section) */
.gallery-item.has-photo{padding:0}
.gallery-item.has-photo img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 0.7s cubic-bezier(0.34,1.56,0.64,1);
}
.gallery-item.has-photo:hover img{transform:scale(1.05)}
.gallery-item.has-photo::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(43,43,43,0.55) 100%);
  pointer-events:none;
  z-index:2;
}
.gallery-item.has-photo .gi-title{color:#ffffff;z-index:3}
.gallery-item.has-photo .gi-tag{color:var(--champagne-light);z-index:3}

/* Birthday Balloons — horizontal scrolling square gallery */
#gallery .gallery-grid,#birthday-balloons .gallery-grid{
  display:flex;
  grid-template-columns:none;
  grid-template-rows:none;
  gap:24px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-padding:0 24px;
  padding:8px 4px 28px;
  margin:0 -4px;
  -webkit-overflow-scrolling:touch;
  scrollbar-color:var(--champagne) var(--cream-3);
  scrollbar-width:thin;
}
#gallery .gallery-grid::-webkit-scrollbar,
#birthday-balloons .gallery-grid::-webkit-scrollbar{
  height:10px;
}
#gallery .gallery-grid::-webkit-scrollbar-track,
#birthday-balloons .gallery-grid::-webkit-scrollbar-track{
  background:var(--cream-3);
  border-radius:10px;
}
#gallery .gallery-grid::-webkit-scrollbar-thumb,
#birthday-balloons .gallery-grid::-webkit-scrollbar-thumb{
  background:var(--champagne);
  border-radius:10px;
  border:2px solid var(--cream-3);
}
#gallery .gallery-grid::-webkit-scrollbar-thumb:hover,
#birthday-balloons .gallery-grid::-webkit-scrollbar-thumb:hover{
  background:var(--champagne-dark);
}
#gallery .gallery-item,#birthday-balloons .gallery-item{
  flex:0 0 auto;
  width:380px;
  height:380px;
  border-radius:24px;
  scroll-snap-align:start;
  padding:0;
}
#gallery .gallery-item.has-photo img,
#birthday-balloons .gallery-item.has-photo img{
  border-radius:24px;
}
#birthday-balloons .gallery-item.has-photo::after{display:none}

/* Founder / portrait section */
.founder-section{
  padding:120px 0 140px;
  background:var(--cream-2);
  position:relative;
}
.founder-grid{
  display:grid;
  grid-template-columns:0.85fr 1fr;
  gap:90px;
  align-items:center;
}
.founder-photo{
  position:relative;
  width:100%;
  max-width:440px;
  aspect-ratio:4 / 5;
  margin:0 auto;
  border-radius:240px 240px 24px 24px;
  overflow:hidden;
  box-shadow:var(--shadow-lift);
  background:var(--cream);
}
.founder-photo::before{
  content:'';
  position:absolute;
  inset:14px;
  border:1px solid rgba(201,150,92,0.4);
  border-radius:230px 230px 14px 14px;
  pointer-events:none;
  z-index:2;
}
.founder-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.founder-text .section-title{margin-bottom:24px}
.founder-text .section-lead{font-size:17px;line-height:1.85}
@media (max-width:1100px){
  .founder-grid{grid-template-columns:1fr;gap:60px;text-align:center}
  .founder-text .section-eyebrow{justify-content:center}
  .founder-text .section-eyebrow::before{display:none}
  .founder-photo{max-width:380px}
}
@media (max-width:768px){
  .founder-section{padding:90px 0 100px}
  .founder-photo{max-width:320px;border-radius:180px 180px 20px 20px}
  .founder-photo::before{border-radius:170px 170px 12px 12px}
}
@media (max-width:480px){
  .founder-section{padding:70px 0 80px}
  .founder-photo{max-width:280px;border-radius:140px 140px 18px 18px}
  .founder-photo::before{border-radius:132px 132px 10px 10px}
}

/* Gallery filter pills */
.gallery-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:48px;
  padding:0;
}
.filter-pill{
  font-family:'Raleway',sans-serif;
  font-size:13px;
  font-weight:500;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--charcoal-soft);
  background:transparent;
  border:1px solid var(--taupe);
  border-radius:999px;
  padding:11px 22px;
  cursor:pointer;
  transition:all 0.35s cubic-bezier(0.34,1.56,0.64,1);
  white-space:nowrap;
}
.filter-pill:hover{
  border-color:var(--champagne-dark);
  color:var(--champagne-dark);
  transform:translateY(-2px);
}
.filter-pill.active{
  background:var(--champagne);
  border-color:var(--champagne);
  color:#ffffff;
  box-shadow:0 8px 22px rgba(212,176,140,0.35);
}
.gallery-item.is-hidden{
  display:none !important;
}
.gallery-item{
  animation:fadeIn 0.5s ease both;
}
@keyframes fadeIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

/* Portfolio gallery — let each card size to its photo's natural aspect */
#gallery .gallery-item{
  width:auto;
  height:460px;
  background:var(--cream);
}
#gallery .gallery-item.has-photo img{
  position:static;
  width:auto;
  height:100%;
  max-width:none;
  object-fit:cover;
  display:block;
  border-radius:24px;
}
#birthday-balloons .gi-tag{color:var(--champagne-light);z-index:3}
#birthday-balloons .gi-title{color:#ffffff;font-size:18px;bottom:24px;left:28px;z-index:3}
#birthday-balloons .gi-1 .gi-title{font-size:18px;bottom:24px;left:28px}
.bg-1,.bg-2,.bg-3,.bg-4,.bg-5,.bg-6{
  grid-column:auto !important;
  grid-row:auto !important;
  border-radius:24px !important;
}

/* ================= CTA Banner ================= */
.cta-banner{
  padding:140px 0;
  background:var(--cream);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:'';
  position:absolute;
  top:50%;left:50%;
  width:800px;height:800px;
  background:radial-gradient(circle,var(--teal-dim),transparent 60%);
  transform:translate(-50%,-50%);
  pointer-events:none;
}
.cta-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(44px,6vw,90px);
  font-weight:500;
  line-height:1;
  color:var(--ink);
  letter-spacing:-0.02em;
  margin-bottom:36px;
  position:relative;
}
.cta-title em{font-style:italic;color:var(--teal-deep);font-weight:400}
.cta-lead{
  font-size:19px;
  color:var(--ink-soft);
  max-width:580px;
  margin:0 auto 48px;
  line-height:1.75;
  position:relative;
}
.cta-banner .btn-primary{position:relative}
.cta-balloons-left,.cta-balloons-right{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  pointer-events:none;
}
.cta-balloons-left{left:4%}
.cta-balloons-right{right:4%}
.cta-balloon{
  position:absolute;
  border-radius:50%;
  box-shadow:inset -8px -12px 18px rgba(0,0,0,0.12),0 8px 22px rgba(43,62,58,0.12);
}

/* ================= Terms ================= */
.terms{
  padding:160px 0;
  background:var(--ink);
  color:var(--cream);
  border-radius:var(--arch) var(--arch) 0 0;
}
.terms .section-title{color:var(--cream)}
.terms .section-title em{color:var(--peach)}
.terms .section-lead{color:rgba(250,246,240,0.7)}
.terms .section-eyebrow{color:var(--peach)}
.terms .section-eyebrow::before{background:var(--peach)}
.terms-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:30px 60px;
  margin-top:30px;
}
.term{
  padding:34px 0;
  border-top:1px solid rgba(250,246,240,0.12);
  display:flex;gap:30px;
}
.term-num{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:26px;
  color:var(--peach);
  min-width:50px;
  padding-top:2px;
}
.term-body{flex:1}
.term-title{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:500;
  color:var(--cream);
  margin-bottom:10px;
}
.term-desc{
  font-size:14px;
  color:rgba(250,246,240,0.7);
  line-height:1.75;
}
.terms-note{
  text-align:center;
  margin-top:70px;
  padding-top:40px;
  border-top:1px solid rgba(250,246,240,0.12);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:22px;
  color:var(--peach-light);
}

/* ================= FAQ ================= */
.faq{padding:160px 0}
.faq-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:80px;
  align-items:start;
}
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  overflow:hidden;
  transition:all 0.3s;
}
.faq-item:hover{border-color:var(--teal-border)}
.faq-item.open{background:var(--cream-2);border-color:var(--teal-border)}
.faq-q{
  width:100%;
  padding:26px 30px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:'Playfair Display',serif;
  font-size:19px;font-weight:500;
  color:var(--ink);
  text-align:left;
}
.faq-icon{
  width:32px;height:32px;
  border-radius:50%;
  background:var(--cream-3);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all 0.4s;
  color:var(--teal-deep);
  font-size:16px;
}
.faq-item.open .faq-icon{
  background:var(--teal-deep);
  color:var(--cream);
  transform:rotate(45deg);
}
.faq-a{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.5s cubic-bezier(0.77,0,0.175,1);
}
.faq-a-inner{
  padding:0 30px 28px 30px;
  font-size:15px;
  color:var(--ink-soft);
  line-height:1.75;
}

/* ================= Contact ================= */
.contact{
  padding:160px 0;
  background:var(--cream-2);
  border-radius:var(--arch) var(--arch) 0 0;
}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:80px;
  align-items:start;
}
.contact-info-list{
  display:flex;flex-direction:column;gap:30px;
  margin-top:40px;
}
.contact-item{
  display:flex;gap:22px;align-items:flex-start;
  padding-bottom:30px;
  border-bottom:1px solid var(--line);
}
.contact-item:last-child{border-bottom:none}
.contact-item-icon{
  width:52px;height:52px;
  border-radius:50%;
  background:var(--cream);
  border:1px solid var(--teal-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--teal-deep);
  flex-shrink:0;
}
.contact-item-label{
  font-size:11px;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:6px;
}
.contact-item-value{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:500;
  color:var(--ink);
  display:block;
  transition:color 0.3s;
}
.contact-item-value:hover{color:var(--champagne-dark)}
.contact-socials{
  display:flex;
  gap:14px;
  padding-top:8px;
}
.social-btn{
  width:52px;height:52px;
  border-radius:50%;
  background:var(--cream);
  border:1px solid var(--taupe);
  display:flex;align-items:center;justify-content:center;
  color:var(--charcoal-soft);
  transition:all 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
.social-btn:hover{
  background:var(--champagne);
  border-color:var(--champagne);
  color:#ffffff;
  transform:translateY(-3px);
  box-shadow:0 8px 20px rgba(212,176,140,0.35);
}

.contact-form{
  background:var(--cream);
  padding:56px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{margin-bottom:22px}
.form-label{
  display:block;
  font-size:11px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:10px;
}
.form-input,.form-select,.form-textarea{
  width:100%;
  padding:16px 18px;
  background:var(--cream-2);
  border:1px solid transparent;
  border-radius:12px;
  font-family:inherit;
  font-size:15px;
  color:var(--ink);
  transition:all 0.3s;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;
  border-color:var(--teal);
  background:var(--cream);
  box-shadow:0 0 0 4px var(--teal-dim);
}
.form-textarea{resize:vertical;min-height:120px;font-family:inherit}
.form-submit{
  width:100%;
  padding:20px;
  background:var(--champagne);
  color:#ffffff;
  border-radius:999px;
  font-size:13px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  transition:all 0.3s;
  margin-top:8px;
}
.form-submit:hover{background:var(--champagne-dark);transform:translateY(-2px);box-shadow:0 12px 30px rgba(212,176,140,0.4)}
.form-submit:disabled{opacity:0.7;cursor:wait;transform:none;box-shadow:none}
.form-status{
  margin-top:18px;
  font-size:14px;
  text-align:center;
  min-height:1.4em;
  color:transparent;
  transition:color 0.3s;
}
.form-status.is-success{color:var(--champagne-dark);font-weight:500}
.form-status.is-error{color:#b8534f;font-weight:500}

/* ================= Footer ================= */
.footer{
  background:var(--ink);
  color:var(--cream);
  padding:100px 0 50px;
  position:relative;
  overflow:hidden;
}
.footer::before{
  content:'Air & Glow';
  position:absolute;
  bottom:-30px;left:50%;
  transform:translateX(-50%);
  font-family:'Playfair Display',serif;
  font-size:clamp(140px,20vw,300px);
  font-style:italic;
  font-weight:500;
  color:rgba(250,246,240,0.04);
  white-space:nowrap;
  pointer-events:none;
  line-height:1;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:80px;
  margin-bottom:80px;
  position:relative;
  z-index:2;
}
.footer-brand{
  display:flex;align-items:center;
  margin-bottom:20px;
}
.footer-brand img{
  height:90px;
  width:auto;
  display:block;
  filter:brightness(0) invert(1) sepia(0.2) saturate(0.6);
  opacity:0.95;
}
.footer-tagline{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:20px;
  color:var(--gold-light);
  margin-bottom:26px;
}
.footer-text{
  font-size:14px;
  color:rgba(250,246,240,0.6);
  line-height:1.8;
  max-width:360px;
}
.footer-col h4{
  font-size:11px;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--peach);
  margin-bottom:24px;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:14px}
.footer-col a{
  font-family:'Playfair Display',serif;
  font-size:17px;
  color:var(--cream);
  opacity:0.75;
  transition:all 0.3s;
}
.footer-col a:hover{opacity:1;color:var(--peach-light);padding-left:8px}
.footer-bottom{
  padding-top:40px;
  border-top:1px solid rgba(250,246,240,0.12);
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;
  color:rgba(250,246,240,0.5);
  position:relative;
  z-index:2;
}
.footer-bottom a{
  color:var(--champagne);
  transition:color 0.3s;
}
.footer-bottom a:hover{color:var(--champagne-light)}

/* ================= Scroll reveal ================= */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal.in{opacity:1;transform:none}
.reveal-2{opacity:0;filter:blur(6px);transform:translateY(16px);transition:opacity 0.8s ease,filter 0.8s ease,transform 0.8s ease}
.reveal-2.in{opacity:1;filter:blur(0);transform:none}
.rd-1{transition-delay:0.1s}
.rd-2{transition-delay:0.2s}
.rd-3{transition-delay:0.3s}
.rd-4{transition-delay:0.4s}
.rd-5{transition-delay:0.5s}

/* ================= Scroll to top ================= */
.scroll-top{
  position:fixed;
  bottom:32px;right:32px;
  width:54px;height:54px;
  border-radius:50%;
  background:var(--champagne);
  color:#ffffff;
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:all 0.4s;
  z-index:90;
  box-shadow:var(--shadow-lift);
}
.scroll-top.show{opacity:1;pointer-events:auto}
.scroll-top:hover{background:var(--champagne-dark);transform:translateY(-4px)}

/* ================= Responsive ================= */
@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr;gap:80px}
  .hero-visual{height:460px;max-width:380px;margin:0 auto}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid,.faq-grid,.contact-grid{grid-template-columns:1fr;gap:60px}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:60px 30px}
  .process-grid::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:50px}
  /* Portfolio gallery uses horizontal scroll layout (defined globally) */
  /* Portfolio — smaller cards on tablet */
  #gallery .gallery-item{width:auto;height:380px}
}
@media (max-width:768px){
  .container,.nav-inner{padding:0 24px;max-width:100%}
  .nav-links{display:none}
  .mobile-toggle{display:flex}
  .nav-logo{height:44px}
  .nav.scrolled .nav-logo{height:38px}
  .section,.services,.process,.gallery,.faq,.contact,.terms,.occasions,.about,.cta-banner{padding:90px 0}
  /* Opener logo: constrain to viewport so it never overflows narrow phones */
  .opener-wrap{
    height:clamp(110px,26vw,220px);
    max-width:calc(100vw - 40px);
  }
  .opener-wrap img{max-width:100%}
  /* Hero */
  .hero{padding:130px 0 70px;min-height:auto}
  .hero-title{font-size:clamp(40px,11vw,64px);line-height:1}
  .hero-lead{font-size:17px;margin-bottom:36px}
  .hero-grid{gap:60px}
  .hero-visual{height:400px;max-width:100%}
  .arch-frame{max-width:320px}
  .hero-stat{position:static;transform:none;margin:24px auto 0;max-width:220px}
  .section-title{font-size:clamp(32px,8vw,50px);line-height:1.05}
  .section-head{margin-bottom:56px}
  /* About */
  .about{padding:80px 0}
  .about-grid{gap:50px}
  .about-visual{height:auto;max-width:100%}
  .about-arch{
    position:static;
    padding:48px 28px;
    border-radius:24px;
    height:auto;
    gap:24px;
  }
  .about-arch::before{display:none}
  .about-logo-mark{margin-bottom:12px}
  .about-logo-mark img{max-height:120px;width:100%;max-width:260px;object-fit:contain}
  .about-values{max-width:100%;gap:20px 16px}
  .about-value-num{font-size:26px}
  .about-value-label{font-size:10px}
  .about-quote{font-size:21px;padding-left:22px;line-height:1.45}
  .about-values{gap:18px;max-width:280px}
  .about-value-num{font-size:30px}
  /* Services */
  .services{padding:80px 0}
  .services-grid{grid-template-columns:1fr;gap:24px}
  .service-card{padding:50px 28px 36px;border-radius:140px 140px 20px 20px}
  .service-card::before{border-radius:134px 134px 12px 12px}
  .service-title{font-size:24px}
  /* Why/Occasions dark section */
  .occasions{padding:120px 0 90px;border-radius:100% 100% 0 0 / 50px 50px 0 0}
  .occasions .section-head{margin-bottom:40px}
  .why-grid{grid-template-columns:1fr;gap:18px}
  .why-card{padding:36px 28px}
  .why-title{font-size:24px}
  /* Soften other arched sections on mobile so content doesn't get clipped */
  .gallery,.contact,.terms{border-radius:100% 100% 0 0 / 50px 50px 0 0}
  .about{border-radius:0 0 100% 100% / 0 0 50px 50px}
  /* Process */
  .process{padding:80px 0}
  .process-grid{grid-template-columns:1fr;gap:50px}
  .process-grid::before{display:none}
  /* Gallery */
  .gallery{padding:80px 0}
  /* Portfolio gallery stays as horizontal scroll on phones (defined globally) */
  #gallery .gallery-grid,#birthday-balloons .gallery-grid{
    display:flex;
    gap:14px;
    padding:8px 0 22px;
    margin:0;
    scroll-padding-left:0;
  }
  #gallery .section-head,#birthday-balloons .section-head{margin-bottom:32px}
  #gallery .gallery-grid::-webkit-scrollbar,
  #birthday-balloons .gallery-grid::-webkit-scrollbar{height:6px}
  #gallery .gallery-item{width:auto;height:320px;flex:0 0 auto}
  .gi-1 .gi-title{font-size:20px;bottom:26px;left:28px}
  /* CTA Banner */
  .cta-banner{padding:90px 0}
  .cta-title{font-size:clamp(38px,9vw,60px);line-height:1.02}
  .cta-lead{font-size:17px;margin-bottom:36px}
  .cta-balloons-left,.cta-balloons-right{display:none}
  /* Terms */
  .terms{padding:90px 0}
  .terms-grid{grid-template-columns:1fr;gap:0}
  .term{gap:20px;padding:28px 0}
  .term-num{font-size:22px;min-width:40px}
  .term-title{font-size:20px}
  .terms-note{font-size:19px;margin-top:50px}
  /* FAQ */
  .faq{padding:80px 0}
  .faq-grid{grid-template-columns:1fr;gap:40px}
  .faq-q{padding:22px 22px;font-size:17px;gap:14px}
  .faq-a-inner{padding:0 22px 24px 22px;font-size:14.5px}
  .faq-icon{width:30px;height:30px;font-size:15px}
  /* Contact */
  .contact{padding:90px 0}
  .contact-grid{grid-template-columns:1fr;gap:50px}
  .contact-form{padding:36px 24px}
  .form-row{grid-template-columns:1fr;gap:0}
  .contact-item-value{font-size:19px}
  .contact-item-icon{width:46px;height:46px}
  .contact-socials{flex-wrap:wrap}
  /* Footer */
  .footer{padding:80px 0 40px}
  .footer-grid{grid-template-columns:1fr;gap:50px;margin-bottom:60px}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center}
  .footer-brand img{height:72px}
  .footer::before{font-size:clamp(90px,30vw,180px)}
  /* Page hero */
  .page-hero{padding:130px 0 60px;min-height:auto}
  .page-hero .hero-grid{grid-template-columns:1fr}
  /* Buttons */
  .btn-primary{padding:16px 30px;font-size:13px}
  .btn-ghost{padding:14px 22px;font-size:13px}
  .hero-actions{gap:14px}
  /* Marquee */
  .marquee{padding:28px 0}
  .marquee-item{font-size:32px;gap:44px}
  .marquee-item::after{width:12px;height:12px}
  body{padding-bottom:0;overflow-x:hidden}
  .scroll-top{bottom:24px;right:24px;width:48px;height:48px}
}

@media (max-width:480px){
  .container,.nav-inner{padding:0 20px}
  .opener-wrap{height:clamp(90px,22vw,160px);max-width:calc(100vw - 32px)}
  .hero{padding:120px 0 60px}
  .hero-title{font-size:clamp(36px,10vw,54px)}
  .hero-eyebrow{font-size:11px;letter-spacing:0.18em}
  .hero-lead{font-size:16px}
  .hero-visual{height:400px}
  .arch-frame{max-width:100%}
  .nav-logo{height:40px}
  .nav.scrolled .nav-logo{height:34px}
  .section-title{font-size:clamp(30px,8vw,42px)}
  .section-eyebrow{font-size:11px;letter-spacing:0.18em}
  .about{padding:70px 0}
  .about-arch{padding:40px 22px;gap:18px}
  .about-logo-mark img{max-height:100px;max-width:220px}
  .about-value-num{font-size:22px}
  .about-quote{font-size:19px}
  .services{padding:70px 0}
  .service-card{padding:44px 22px 32px;border-radius:110px 110px 16px 16px}
  .service-card::before{border-radius:104px 104px 10px 10px}
  .occasions,.gallery,.faq,.contact,.terms,.cta-banner,.process{padding:70px 0}
  .why-card{padding:32px 24px}
  .contact-form{padding:30px 20px}
  .footer{padding:70px 0 40px}
  .faq-q{padding:20px 18px;font-size:16px}
  .page-hero{padding:110px 0 40px}
  .btn-primary{padding:15px 28px;font-size:12.5px;gap:10px}
  .btn-ghost{padding:13px 20px;font-size:12.5px}
  .marquee-item{font-size:28px;gap:36px}
}

/* ================= Sub-page hero (no arch, no min-height) ================= */
.page-hero{
  padding:180px 0 100px;
  background:var(--cream-2);
  position:relative;
  overflow:hidden;
  text-align:center;
}
.page-hero .section-eyebrow{justify-content:center}
.page-hero .section-title{max-width:800px;margin:0 auto 24px}
.page-hero .section-lead{max-width:600px;margin:0 auto}

/* Nav visible immediately on sub-pages */
.nav.nav-immediate{opacity:1}
