/* ── Portfolio Navigation Bar ───────────────── */
.pflio-bar {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: 40px;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  background: rgba(10, 10, 20, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-family: system-ui, -apple-system, sans-serif;
  font-size: 13px;
  box-sizing: border-box;
}
.pflio-bar a {
  color: rgba(255, 255, 255, 0.75);
  text-decoration: none;
  transition: color 0.2s ease;
  white-space: nowrap;
}
.pflio-bar a:hover { color: #ffffff; }
.pflio-bar a:focus-visible {
  outline: 2px solid rgba(255,255,255,0.5);
  outline-offset: 3px;
  border-radius: 3px;
}
.pflio-bar__back:hover .pflio-bar__arrow { margin-right: 4px; }
.pflio-bar__arrow { display: inline-block; transition: margin 0.2s ease; }
.pflio-bar__label {
  color: rgba(255, 255, 255, 0.45);
  font-size: 12px;
  letter-spacing: 0.02em;
  pointer-events: none;
}
.pflio-bar__diamond {
  color: rgba(255, 255, 255, 0.25);
  margin-right: 6px;
  font-size: 10px;
}
.pflio-bar__arrow-right {
  display: inline-block;
  transition: transform 0.2s ease;
  margin-left: 4px;
}
.pflio-bar__all:hover .pflio-bar__arrow-right { transform: translateX(3px); }
.pflio-bar__all-short { display: none; }

@media (max-width: 600px) {
  .pflio-bar { height: 44px; padding: 0 16px; }
  .pflio-bar__all-text { display: none; }
  .pflio-bar__all-short { display: inline; }
}
@media (max-width: 480px) {
  .pflio-bar__label { display: none; }
}
body { padding-top: 40px; }
@media (max-width: 600px) { body { padding-top: 44px; } }
/* ── End Portfolio Navigation Bar ───────────── */

/* FESTA LONDON — Vibrant & Celebratory | Golden Yellow · Tropical Green · White | Pacifico + Nunito */
:root{
  --clr-yellow:#F5A623;--clr-yellow-lt:#F7BA52;--clr-yellow-dk:#D4880A;
  --clr-green:#1B5E20;--clr-green-lt:#2E7D32;
  --clr-white:#FFFFFF;--clr-cream:#FFFBF2;
  --clr-text:#1A2E1A;--clr-text-lt:#5A6B3A;
  --clr-wa:#25D366;--clr-wa-dk:#1EB858;
  --font-display:'Pacifico',cursive;--font-body:'Nunito',system-ui,sans-serif;
  --sp-sm:1rem;--sp-md:1.5rem;--sp-lg:2.5rem;--sp-xl:4rem;--sp-2xl:6rem;
  --radius:16px;--radius-sm:10px;--transition:240ms ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:clamp(1rem,1.1vw,1.05rem);line-height:1.75;color:var(--clr-text);background:var(--clr-cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
address{font-style:normal}
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--clr-green);color:#fff;padding:.5em 1em;z-index:9999;font-weight:700}
.skip-link:focus{top:1rem}
.container{width:min(92%,1240px);margin-inline:auto}
/* CONFETTI */
.confetti{position:fixed;top:0;left:0;width:100%;pointer-events:none;z-index:1000;overflow:hidden;height:100vh}
.confetti span{position:absolute;width:10px;height:10px;opacity:0;animation:confetti-fall 4s ease-in forwards}
.confetti span:nth-child(1){left:10%;background:var(--clr-yellow);animation-delay:.2s;transform:rotate(20deg)}
.confetti span:nth-child(2){left:22%;background:var(--clr-green);animation-delay:.5s;border-radius:50%;width:8px;height:8px}
.confetti span:nth-child(3){left:35%;background:#E91E63;animation-delay:.1s;transform:rotate(45deg)}
.confetti span:nth-child(4){left:48%;background:var(--clr-yellow-lt);animation-delay:.7s;width:6px;height:12px}
.confetti span:nth-child(5){left:60%;background:var(--clr-green-lt);animation-delay:.3s;transform:rotate(30deg)}
.confetti span:nth-child(6){left:72%;background:#2196F3;animation-delay:.6s;border-radius:50%}
.confetti span:nth-child(7){left:83%;background:var(--clr-yellow);animation-delay:.4s;transform:rotate(60deg)}
.confetti span:nth-child(8){left:15%;background:#9C27B0;animation-delay:1s;width:12px;height:6px}
.confetti span:nth-child(9){left:30%;background:var(--clr-yellow-dk);animation-delay:.8s;border-radius:50%}
.confetti span:nth-child(10){left:55%;background:#FF5722;animation-delay:.15s;transform:rotate(15deg)}
.confetti span:nth-child(11){left:68%;background:var(--clr-green);animation-delay:.9s;width:8px;height:8px}
.confetti span:nth-child(12){left:78%;background:var(--clr-yellow-lt);animation-delay:.35s;transform:rotate(50deg)}
.confetti span:nth-child(13){left:5%;background:#00BCD4;animation-delay:.55s;border-radius:50%}
.confetti span:nth-child(14){left:42%;background:#FF9800;animation-delay:.75s;transform:rotate(25deg)}
.confetti span:nth-child(15){left:92%;background:var(--clr-green-lt);animation-delay:.45s;width:6px;height:10px}
@keyframes confetti-fall{0%{top:-10px;opacity:1;transform:translateX(0) rotate(0deg)}100%{top:100vh;opacity:0;transform:translateX(calc(-50px + 100px * var(--rand,0.5))) rotate(720deg)}}
/* WHATSAPP */
.whatsapp-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200;background:var(--clr-wa);color:#fff;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.2rem;border-radius:999px;font-family:var(--font-body);font-size:.875rem;font-weight:700;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:all var(--transition)}
.whatsapp-float:hover{background:var(--clr-wa-dk);transform:translateY(-2px)}
@media(min-width:1024px){.whatsapp-float span{display:none}.whatsapp-float{padding:.9rem;border-radius:50%;width:56px;height:56px;justify-content:center}}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8em 2em;border:2px solid transparent;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;font-weight:700;cursor:pointer;transition:all var(--transition)}
.btn--primary{background:var(--clr-yellow);color:var(--clr-green);border-color:var(--clr-yellow)}
.btn--primary:hover{background:var(--clr-yellow-lt);transform:translateY(-2px);box-shadow:0 8px 24px rgba(245,166,35,.3)}
.btn--wa{background:var(--clr-wa);color:#fff;border-color:var(--clr-wa)}
.btn--wa:hover{background:var(--clr-wa-dk)}
.btn--full{width:100%;justify-content:center}
:focus-visible{outline:2px solid var(--clr-yellow-dk);outline-offset:3px}
/* SECTIONS */
.section{padding-block:var(--sp-2xl);background:var(--clr-cream)}
.section--green{background:var(--clr-green);color:#fff}
.section--green .section__eyebrow{color:rgba(255,255,255,.6)}
.section--green .section__title{color:#fff}
.section--yellow{background:var(--clr-yellow)}
.section--yellow .section__eyebrow{color:var(--clr-green)}
.section--yellow .section__title{color:var(--clr-green)}
.section__eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--clr-yellow-dk);display:block;margin-bottom:.5rem}
.section__title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);line-height:1.25;color:var(--clr-text);margin-bottom:var(--sp-md)}
.section__sub{color:var(--clr-text-lt);max-width:600px;margin-bottom:var(--sp-lg)}
/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background var(--transition),box-shadow var(--transition)}
.site-header.scrolled{background:rgba(255,251,242,.97);backdrop-filter:blur(12px);box-shadow:0 3px 0 var(--clr-yellow),0 4px 20px rgba(245,166,35,.15)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{font-family:var(--font-display);font-size:1.5rem;color:var(--clr-green)}
.logo em{font-style:normal;color:var(--clr-yellow-dk)}
.nav__list{display:none;gap:var(--sp-lg)}
.nav__link{font-size:.85rem;font-weight:700;color:var(--clr-text-lt);transition:color var(--transition)}
.nav__link:hover{color:var(--clr-yellow-dk)}
.nav__link--cta{background:var(--clr-yellow);color:var(--clr-green);padding:.45em 1.3em;border-radius:var(--radius-sm)}
.nav__link--cta:hover{background:var(--clr-yellow-lt)}
.nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--clr-text);transition:transform var(--transition),opacity var(--transition)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{background:var(--clr-cream);border-top:3px solid var(--clr-yellow);padding:var(--sp-md) 5%}
.mobile-nav[hidden]{display:none}
.mobile-nav ul{display:flex;flex-direction:column;gap:var(--sp-sm)}
.mobile-nav a{font-size:1rem;font-weight:700;color:var(--clr-text-lt);padding:.5rem 0;display:block;border-bottom:1px solid rgba(245,166,35,.2)}
.mobile-nav a:hover{color:var(--clr-yellow-dk)}
/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__video-wrap{position:absolute;inset:0}
.hero__video{width:100%;height:100%;object-fit:cover}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,94,32,.92) 0%,rgba(27,94,32,.7) 50%,rgba(27,94,32,.4) 100%)}
.hero__content{position:relative;z-index:1;padding-top:5rem;max-width:640px}
.hero__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--clr-yellow-lt);display:block;margin-bottom:1.25rem}
.hero__title{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,4.8rem);line-height:1.2;color:#fff;margin-bottom:var(--sp-md);text-shadow:0 2px 12px rgba(0,0,0,.2)}
.hero__sub{color:rgba(255,255,255,.85);font-size:1rem;max-width:500px;margin-bottom:var(--sp-lg);font-weight:500}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--sp-sm)}
/* PACKAGES */
.packages__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:var(--sp-md);margin-top:var(--sp-lg)}
.package-card{background:var(--clr-white);padding:var(--sp-lg) var(--sp-md);border-radius:var(--radius);border:2px solid transparent;transition:all var(--transition);text-align:center}
.package-card:hover{border-color:var(--clr-yellow);transform:translateY(-4px);box-shadow:0 12px 32px rgba(245,166,35,.15)}
.package-card--featured{border-color:var(--clr-yellow);background:rgba(245,166,35,.05)}
.package-card__emoji{font-size:2.5rem;margin-bottom:.75rem;display:block}
.package-card h3{font-family:var(--font-display);font-size:1.15rem;color:var(--clr-green);margin-bottom:.5rem}
.package-card p{font-size:.875rem;color:var(--clr-text-lt);line-height:1.65;margin-bottom:var(--sp-sm)}
.package-price{font-family:var(--font-display);font-size:1.5rem;color:var(--clr-yellow-dk)}
.package-price span{font-family:var(--font-body);font-size:.8rem;color:var(--clr-text-lt);font-weight:600}
/* GALLERY */
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:8px;margin-top:var(--sp-lg)}
.gallery__item{overflow:hidden;margin:0;border-radius:var(--radius-sm)}
.gallery__item--wide{grid-column:span 2}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .4s ease;filter:brightness(.9)}
.gallery__item:hover img{transform:scale(1.06);filter:brightness(1)}
/* STORY */
.story__inner{display:grid;grid-template-columns:1fr;gap:var(--sp-xl);align-items:center}
.story__image img{width:100%;border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover}
.story__text p{color:var(--clr-text-lt);margin-bottom:var(--sp-sm)}
.story__text strong{color:var(--clr-text)}
/* EVENTS */
.events__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:var(--sp-md);margin-top:var(--sp-lg)}
.event-card{background:rgba(255,255,255,.6);backdrop-filter:blur(8px);border:2px solid rgba(27,94,32,.15);border-radius:var(--radius);padding:var(--sp-md);display:flex;gap:var(--sp-md);align-items:flex-start}
.event-card__date{background:var(--clr-green);color:#fff;border-radius:var(--radius-sm);padding:.5rem .75rem;text-align:center;flex-shrink:0;min-width:56px}
.event-day{display:block;font-family:var(--font-display);font-size:1.5rem;line-height:1}
.event-month{display:block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.8}
.event-card__info h3{font-family:var(--font-body);font-size:1rem;font-weight:800;color:var(--clr-green);margin-bottom:.4rem}
.event-card__info p{font-size:.85rem;color:var(--clr-text-lt);line-height:1.6;margin-bottom:.5rem}
.event-location{font-size:.8rem;font-weight:700;color:var(--clr-yellow-dk)}
/* TESTIMONIALS */
.testimonials__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:var(--sp-md);margin-top:var(--sp-lg)}
.testimonial{background:var(--clr-white);border:2px solid rgba(245,166,35,.2);border-radius:var(--radius);padding:var(--sp-lg) var(--sp-md)}
.stars{color:var(--clr-yellow-dk);font-size:1.2rem;margin-bottom:.75rem}
.testimonial p{font-size:.875rem;color:var(--clr-text-lt);font-style:italic;line-height:1.75;margin-bottom:var(--sp-sm)}
.testimonial footer strong{display:block;font-family:var(--font-body);font-size:.95rem;font-weight:800;color:var(--clr-text)}
.testimonial footer span{font-size:.78rem;color:var(--clr-text-lt)}
/* BOOKING */
.booking__inner{display:grid;grid-template-columns:1fr;gap:var(--sp-xl)}
.booking__info p{color:var(--clr-green);margin-bottom:var(--sp-sm)}
.contact-block{margin:var(--sp-md) 0;padding:var(--sp-md);background:rgba(27,94,32,.08);border-left:4px solid var(--clr-green);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.contact-block p{font-size:.875rem;margin-bottom:.4rem;color:var(--clr-green)}
.contact-block a{color:var(--clr-green);font-weight:700}
.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:var(--sp-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-sm)}
.form-group label{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-green)}
.form-group input,.form-group select,.form-group textarea{padding:.8rem 1rem;border:2px solid rgba(27,94,32,.2);background:rgba(255,255,255,.8);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;color:var(--clr-text);transition:border-color var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--clr-green);background:#fff}
.form-error{font-size:.8rem;color:#DC2626;min-height:1.1em}
.form-success{font-family:var(--font-display);font-size:1.1rem;color:var(--clr-green);text-align:center;margin-top:var(--sp-sm)}
/* FOOTER */
.site-footer{background:var(--clr-green);color:rgba(255,255,255,.65)}
.footer__inner{display:grid;grid-template-columns:1fr;gap:var(--sp-xl);padding:var(--sp-2xl) 0 var(--sp-xl);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__logo{font-family:var(--font-display);font-size:1.5rem;color:#fff;margin-bottom:.75rem}
.footer__logo em{font-style:normal;color:var(--clr-yellow)}
.footer__col p{font-size:.875rem;line-height:1.7}
.footer__wa{display:inline-flex;align-items:center;gap:.4rem;margin-top:var(--sp-sm);background:var(--clr-wa);color:#fff;font-size:.82rem;font-weight:700;padding:.5em 1em;border-radius:999px}
.footer__wa:hover{background:var(--clr-wa-dk)}
.footer__col h3{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:.75rem}
.footer__col li a,.footer__col address a{font-size:.875rem;color:rgba(255,255,255,.5);transition:color var(--transition)}
.footer__col li a:hover,.footer__col address a:hover{color:var(--clr-yellow)}
.footer__col address{font-size:.875rem;line-height:1.9}
.footer__col ul{display:flex;flex-direction:column;gap:.4rem}
.footer__bottom{padding:var(--sp-md) 0;text-align:center;font-size:.78rem;color:rgba(255,255,255,.25)}
@media(min-width:768px){.nav__list{display:flex}.nav-toggle{display:none}.mobile-nav{display:none!important}.story__inner{grid-template-columns:1fr 1fr}.booking__inner{grid-template-columns:1fr 1fr}.footer__inner{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer__inner{grid-template-columns:2fr 1fr 1fr 1.5fr}.gallery__grid{grid-auto-rows:220px}}
@media(max-width:767px){.gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}.gallery__item--wide{grid-column:span 1}.form-row{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}html{scroll-behavior:auto}}