/* ===== Envision Event Rentals — Bold Playful Celebration ===== */
:root{
  --pink:#ff2e8b;       /* magenta */
  --pink-soft:#ff5fae;
  --teal:#00c2c7;
  --teal-soft:#3ee0e4;
  --yellow:#ffd23f;
  --yellow-soft:#ffe066;
  --purple:#7b2ff7;
  --purple-soft:#a06bff;
  --ink:#241a33;        /* deep plum-charcoal text */
  --ink-soft:#5a4f68;
  --paper:#ffffff;
  --cloud:#fbf7ff;      /* faint lilac page bg */
  --mint:#eafcfc;
  --radius:22px;
  --radius-sm:14px;
  --shadow:0 14px 36px -16px rgba(123,47,247,.28);
  --shadow-lg:0 26px 60px -22px rgba(255,46,139,.36);
  --maxw:1120px;
  --font:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--cloud);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* skip link */
.skip-link{
  position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;
  padding:12px 18px;border-radius:0 0 12px 0;z-index:200;font-weight:600;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--purple);outline-offset:3px;border-radius:6px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  min-height:50px;padding:13px 26px;border-radius:999px;font-weight:700;
  font-size:1rem;cursor:pointer;border:none;line-height:1.1;text-align:center;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.btn-primary{background:var(--pink);color:#fff;box-shadow:var(--shadow-lg)}
.btn-primary:hover{transform:translateY(-2px);background:#ff1a7e}
.btn-ghost{background:#fff;color:var(--ink);box-shadow:0 6px 18px -10px rgba(36,26,51,.4)}
.btn-ghost:hover{transform:translateY(-2px);color:var(--pink)}
.btn-block{width:100%}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(123,47,247,.1);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:64px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.15rem;color:var(--ink)}
.logo-mark{display:inline-flex;gap:3px}
.logo-mark .dot{width:9px;height:9px;border-radius:50%}
.dot-pink{background:var(--pink)}.dot-teal{background:var(--teal)}.dot-yellow{background:var(--yellow)}
.logo-text{display:flex;flex-direction:column;line-height:1;letter-spacing:-.01em}
.logo-sub{font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--purple);margin-top:3px}

.main-nav{display:none;align-items:center;gap:26px}
.main-nav a{font-weight:600;font-size:.95rem;color:var(--ink-soft);transition:color .15s}
.main-nav a:hover{color:var(--pink)}
.main-nav .nav-cta{
  background:var(--purple);color:#fff;padding:10px 20px;border-radius:999px;
  box-shadow:0 10px 24px -12px rgba(123,47,247,.7);
}
.main-nav .nav-cta:hover{color:#fff;background:#6a1fe0}

@media(min-width:860px){.main-nav{display:flex}}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 80% at 90% -10%, rgba(255,210,63,.32), transparent 55%),
    radial-gradient(120% 90% at -10% 10%, rgba(0,194,199,.28), transparent 55%),
    linear-gradient(180deg,#fff6fb,#fbf3ff 70%,var(--cloud));
  padding:46px 0 60px;
}
.confetti-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
.hero-blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;z-index:0}
.blob-1{width:200px;height:200px;background:radial-gradient(circle,var(--pink-soft),transparent 70%);top:-40px;left:-40px}
.blob-2{width:240px;height:240px;background:radial-gradient(circle,var(--teal-soft),transparent 70%);bottom:-60px;right:-50px}
.hero-inner{position:relative;z-index:2;display:grid;gap:30px}
.eyebrow{
  display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--purple);
  background:rgba(123,47,247,.1);padding:6px 14px;border-radius:999px;
}
.hero h1{
  font-size:clamp(2.3rem,9vw,3.6rem);line-height:1.04;font-weight:800;
  letter-spacing:-.02em;margin:.5em 0 .35em;
}
.pop{color:var(--pink);display:inline-block;position:relative}
.lede{font-size:1.08rem;color:var(--ink-soft);max-width:30em}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 22px}
.hero-badges{list-style:none;display:flex;flex-wrap:wrap;gap:10px 18px;font-weight:600;font-size:.92rem;color:var(--ink)}
.hero-badges li{display:flex;align-items:center;gap:7px;background:#fff;padding:8px 14px;border-radius:999px;box-shadow:0 8px 20px -14px rgba(36,26,51,.45)}
.hero-art{display:flex;justify-content:center}
.hero-svg{width:min(360px,82vw);filter:drop-shadow(0 24px 40px rgba(123,47,247,.25))}
.balloon-grp{transform-origin:center top}

@media(min-width:860px){
  .hero{padding:70px 0 84px}
  .hero-inner{grid-template-columns:1.05fr .95fr;align-items:center;gap:40px}
  .hero-svg{width:min(420px,40vw)}
}

/* ===== Sections ===== */
.section{padding:60px 0}
.section-head{text-align:center;max-width:40em;margin:0 auto 36px}
.kicker{font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal)}
.section h2{font-size:clamp(1.7rem,5.6vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin:.2em 0 .35em;line-height:1.1}
.section-sub{color:var(--ink-soft);font-size:1.04rem}
.card-note{text-align:center;color:var(--ink-soft);margin-top:26px;font-size:.95rem}
.card-note a{color:var(--pink);font-weight:700;text-decoration:underline;text-underline-offset:3px}

/* ===== Rentals grid ===== */
.card-grid{list-style:none;display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:560px){.card-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.card-grid{grid-template-columns:repeat(3,1fr)}}
.rent-card{
  position:relative;background:rgba(255,255,255,.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(123,47,247,.12);
  border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);
  transition:transform .2s ease,box-shadow .2s ease;
}
.rent-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.rent-ico{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;margin-bottom:16px}
.rent-ico svg{width:36px;height:36px}
.ico-tables{background:#ffe9f3;color:var(--pink)}
.ico-linens{background:#e6fbfb;color:var(--teal)}
.ico-bounce{background:#fff4d6;color:#e0a800}
.ico-marquee{background:#efe6ff;color:var(--purple)}
.ico-dinner{background:#ffe9f3;color:var(--pink)}
.ico-helium{background:#e6fbfb;color:var(--teal)}
.ico-tents{background:#fff4d6;color:#e0a800}
.ico-light{background:#efe6ff;color:var(--purple)}
.ico-floor{background:#ffe9f3;color:var(--pink)}
.rent-card h3{font-size:1.22rem;font-weight:700;margin-bottom:6px}
.rent-card p{color:var(--ink-soft);font-size:.96rem}
.rent-card.soon{border-style:dashed}
.ask-tag{
  position:absolute;top:16px;right:16px;font-size:.68rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--purple);
  background:#efe6ff;padding:4px 10px;border-radius:999px;
}

/* ===== How it works ===== */
.how{background:linear-gradient(180deg,#fff,#fff6fb)}
.steps{list-style:none;display:grid;gap:20px;counter-reset:s}
@media(min-width:760px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{
  background:#fff;border-radius:var(--radius);padding:28px 24px;
  box-shadow:var(--shadow);text-align:center;position:relative;
}
.step-num{
  display:grid;place-items:center;width:54px;height:54px;margin:0 auto 14px;
  border-radius:50%;font-weight:800;font-size:1.4rem;color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--purple));
  box-shadow:0 12px 24px -10px rgba(255,46,139,.6);
}
.step:nth-child(2) .step-num{background:linear-gradient(135deg,var(--teal),var(--purple))}
.step:nth-child(3) .step-num{background:linear-gradient(135deg,var(--yellow),var(--pink))}
.step h3{font-size:1.18rem;font-weight:700;margin-bottom:6px}
.step p{color:var(--ink-soft);font-size:.96rem}

/* ===== Gallery ===== */
.gal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(min-width:760px){.gal-grid{grid-template-columns:repeat(3,1fr)}}
.gal-item{
  border-radius:var(--radius);min-height:140px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:8px;color:#fff;font-weight:700;
  box-shadow:var(--shadow);text-align:center;padding:18px;
  transition:transform .2s ease;
}
.gal-item:hover{transform:scale(1.03) rotate(-1deg)}
.gal-emoji{font-size:2.4rem;line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.18))}
.gal-item figcaption{font-size:1rem;text-shadow:0 2px 8px rgba(0,0,0,.25)}
.g-pink{background:linear-gradient(135deg,var(--pink),var(--pink-soft))}
.g-teal{background:linear-gradient(135deg,var(--teal),var(--teal-soft))}
.g-yellow{background:linear-gradient(135deg,#e0a800,var(--yellow));color:#3a2a00}
.g-yellow figcaption,.g-yellow .gal-emoji{text-shadow:none}
.g-purple{background:linear-gradient(135deg,var(--purple),var(--purple-soft))}
.g-pink2{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft))}
.g-teal2{background:linear-gradient(135deg,var(--teal-soft),var(--teal))}

/* ===== About ===== */
.about{background:linear-gradient(180deg,#fff6fb,#fff)}
.about-inner{display:grid;gap:30px;align-items:center}
@media(min-width:860px){.about-inner{grid-template-columns:.8fr 1.2fr;gap:48px}}
.about-svg{width:min(220px,60vw);margin:0 auto;filter:drop-shadow(0 18px 30px rgba(123,47,247,.3))}
.about-copy h2{margin-top:.1em}
.about-copy p{color:var(--ink-soft);margin-bottom:14px;font-size:1.02rem}
.about-copy .btn{margin-top:8px}

/* ===== Reviews ===== */
.reviews{background:linear-gradient(180deg,#fff,#f6fdfd)}
.rating-line{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:8px}
.stars{color:var(--yellow);font-size:1.4rem;letter-spacing:2px;text-shadow:0 2px 6px rgba(255,210,63,.5)}
.rating-val{font-weight:800;font-size:1.3rem}
.rating-meta{color:var(--ink-soft);font-size:.95rem}
.review-grid{list-style:none;display:grid;gap:18px}
@media(min-width:760px){.review-grid{grid-template-columns:repeat(3,1fr)}}
.review-card{
  position:relative;background:#fff;border-radius:var(--radius);
  padding:30px 24px 24px;box-shadow:var(--shadow);
  border-top:5px solid var(--pink);
}
.review-card:nth-child(2){border-top-color:var(--teal)}
.review-card:nth-child(3){border-top-color:var(--yellow)}
.review-card p{color:var(--ink);font-size:1rem}
.quote-mark{
  position:absolute;top:-6px;left:18px;font-size:3.4rem;line-height:1;
  color:var(--purple-soft);font-family:Georgia,serif;opacity:.5;
}

/* ===== Service area ===== */
.area{background:linear-gradient(180deg,#f6fdfd,#fff)}
.area-inner{display:grid;gap:30px;align-items:center}
@media(min-width:860px){.area-inner{grid-template-columns:1.1fr .9fr;gap:48px}}
.area-copy p{color:var(--ink-soft);font-size:1.02rem;margin-bottom:16px}
.area-chips{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.area-chips li{
  background:#fff;border:1px solid rgba(0,194,199,.3);color:var(--ink);
  font-weight:600;font-size:.92rem;padding:8px 16px;border-radius:999px;
  box-shadow:0 6px 16px -12px rgba(0,194,199,.6);
}
.area-map svg{width:100%;border-radius:18px;box-shadow:var(--shadow)}

/* ===== Contact ===== */
.contact{
  background:
    radial-gradient(110% 80% at 100% 0%, rgba(255,46,139,.14), transparent 55%),
    radial-gradient(110% 80% at 0% 100%, rgba(123,47,247,.14), transparent 55%),
    linear-gradient(180deg,#fff,#fbf3ff);
}
.contact-inner{display:grid;gap:30px}
@media(min-width:860px){.contact-inner{grid-template-columns:1fr 1.05fr;gap:48px;align-items:start}}
.contact-copy p{color:var(--ink-soft);font-size:1.04rem;margin-bottom:18px}
.contact-list{list-style:none;display:grid;gap:12px;font-weight:600}
.contact-list li{display:flex;align-items:center;gap:12px}
.contact-list .ci{font-size:1.2rem}
.contact-list a{color:var(--pink)}
.contact-list a:hover{text-decoration:underline}

.quote-form{
  background:#fff;border-radius:var(--radius);padding:26px 22px;
  box-shadow:var(--shadow-lg);border:1px solid rgba(123,47,247,.1);
}
.field{margin-bottom:16px}
.field-row{display:grid;gap:16px}
@media(min-width:480px){.field-row{grid-template-columns:1fr 1fr}}
.quote-form label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.quote-form input,.quote-form textarea{
  width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  padding:13px 14px;border:2px solid #ece3f5;border-radius:var(--radius-sm);
  background:#fcfaff;min-height:48px;transition:border-color .15s,box-shadow .15s;
}
.quote-form textarea{min-height:auto;resize:vertical}
.quote-form input:focus,.quote-form textarea:focus{
  outline:none;border-color:var(--pink);box-shadow:0 0 0 4px rgba(255,46,139,.12);
}
.quote-form .btn-block{margin-top:6px}
.form-msg{margin-top:12px;font-weight:600;min-height:1.2em}
.form-msg.ok{color:var(--teal)}
.form-msg.err{color:var(--pink)}
.form-fine{margin-top:12px;font-size:.88rem;color:var(--ink-soft);text-align:center}
.form-fine a{color:var(--pink);font-weight:700}

/* ===== Footer ===== */
.site-footer{background:var(--ink);color:#efe7f7;padding:46px 0 26px}
.footer-inner{display:grid;gap:26px}
@media(min-width:760px){.footer-inner{grid-template-columns:1.4fr 1fr 1fr;gap:40px}}
.site-footer .logo{color:#fff;margin-bottom:12px}
.site-footer .logo-sub{color:var(--yellow-soft)}
.foot-brand p{color:#b9adc9;font-size:.95rem;max-width:30em}
.foot-nav{display:grid;gap:10px;align-content:start}
.foot-nav a{color:#cfc3df;font-weight:600;font-size:.95rem}
.foot-nav a:hover{color:var(--yellow)}
.foot-contact{display:grid;gap:8px;align-content:start}
.foot-contact a{color:#fff;font-weight:700;font-size:1.05rem}
.foot-contact span{color:#b9adc9;font-size:.92rem}
.copyright{text-align:center;color:#8c809c;font-size:.85rem;margin-top:30px;border-top:1px solid rgba(255,255,255,.1);padding-top:20px}

/* ===== Sticky mobile CTA ===== */
.sticky-cta{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:120;
  background:var(--pink);color:#fff;text-align:center;font-weight:700;
  padding:15px;border-radius:999px;box-shadow:var(--shadow-lg);
  min-height:50px;display:flex;align-items:center;justify-content:center;
}
.sticky-cta:hover{background:#ff1a7e}
@media(min-width:860px){.sticky-cta{display:none}}
@media(max-width:859px){main{padding-bottom:84px}}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(22px) scale(.97)}
.reveal.in{opacity:1;transform:none;transition:opacity .55s ease,transform .55s cubic-bezier(.2,.9,.3,1.2)}

/* ===== Reduced motion ===== */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .confetti-canvas{display:none}
}
