/*
Theme Name: Southern Inflatables
Theme URI: https://southerninflatables.co.uk
Author: Southern Inflatables
Author URI: https://southerninflatables.co.uk
Description: A playful, bright one-page theme for bouncy castle and inflatable hire businesses. Add your inflatables from the dashboard and edit your hero video, contact details and colours from the Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: southern-inflatables
*/

:root{
  --blue:#1565C0;
  --blue-deep:#0d4a91;
  --yellow:#F6B916;
  --red:#E53124;
  --navy:#1A2B4A;
  --sky-1:#7ec8ff;
  --sky-2:#bfe6ff;
  --cream:#FFF9EF;
  --white:#ffffff;
  --ink:#1A2B4A;
  --shadow:0 18px 40px -18px rgba(13,74,145,.45);
  --shadow-sm:0 8px 22px -12px rgba(13,74,145,.4);
  --r-lg:28px;
  --r-md:20px;
  --r-sm:14px;
  --display:'Fredoka','Trebuchet MS',system-ui,sans-serif;
  --body:'Nunito',system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.display{font-family:var(--display);line-height:1.05;letter-spacing:.2px;margin:0}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
p{margin:0}
.wrap{width:min(1180px,92vw);margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--display);font-weight:600;font-size:1.02rem;
  padding:.85em 1.6em;border-radius:999px;border:0;cursor:pointer;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,background .2s;
  text-align:center;
}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 0 -2px #b8261c,0 16px 26px -14px rgba(229,49,36,.8)}
.btn-primary:hover{transform:translateY(-3px)}
.btn-primary:active{transform:translateY(2px);box-shadow:0 6px 0 -2px #b8261c}
.btn-sun{background:var(--yellow);color:var(--navy);box-shadow:0 10px 0 -2px #d49a06,0 16px 26px -14px rgba(246,185,22,.85)}
.btn-sun:hover{transform:translateY(-3px)}
.btn-sun:active{transform:translateY(2px);box-shadow:0 6px 0 -2px #d49a06}
.btn-ghost{background:rgba(255,255,255,.18);color:#fff;border:2px solid rgba(255,255,255,.7);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.3);transform:translateY(-3px)}

/* ---------- Nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:14px 0;transition:background .3s,box-shadow .3s,padding .3s}
header.nav.scrolled{background:rgba(255,249,239,.92);backdrop-filter:blur(10px);box-shadow:0 6px 24px -16px rgba(13,74,145,.5);padding:8px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo-mark{width:48px;height:48px;flex:none;filter:drop-shadow(0 4px 8px rgba(13,74,145,.35))}
.brand-text{font-family:var(--display);font-weight:700;color:var(--navy);line-height:1}
.brand-text b{display:block;font-size:1.18rem;letter-spacing:.3px}
.brand-text .tag{display:block;font-size:.62rem;letter-spacing:3px;color:var(--blue);font-weight:600}
header.nav:not(.scrolled) .brand-text b,
header.nav:not(.scrolled) .brand-text .tag{color:#fff;text-shadow:0 2px 8px rgba(13,74,145,.5)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a.link{font-family:var(--display);font-weight:500;font-size:1.02rem;color:var(--navy);position:relative;padding:4px 0}
header.nav:not(.scrolled) .nav-links a.link{color:#fff;text-shadow:0 1px 6px rgba(13,74,145,.5)}
.nav-links a.link::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:3px;border-radius:3px;background:var(--yellow);transition:width .25s}
.nav-links a.link:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:3px;border-radius:3px;background:var(--navy);margin:5px 0;transition:.3s}
header.nav:not(.scrolled) .nav-toggle span{background:#fff}

/* ---------- Hero ---------- */
.hero{min-height:100svh;display:flex;align-items:center;overflow:hidden;color:#fff;background:linear-gradient(180deg,var(--sky-1) 0%,var(--sky-2) 60%,#eaf7ff 100%)}
.hero-video,.hero-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-video{opacity:0}
.hero.has-video .hero-video{opacity:1}
.hero::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(13,74,145,.35),rgba(13,74,145,.12) 35%,rgba(13,74,145,.55))}
.hero .wrap{position:relative;z-index:3;padding:120px 0 90px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.5);backdrop-filter:blur(4px);padding:7px 16px;border-radius:999px;font-size:.92rem;letter-spacing:.5px;margin-bottom:22px}
.eyebrow .dot{width:9px;height:9px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 4px rgba(246,185,22,.35)}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);font-weight:700;text-shadow:0 6px 30px rgba(13,74,145,.4);max-width:13ch}
.hero h1 .pop{color:var(--yellow);display:inline-block;animation:wiggle 3.5s ease-in-out infinite}
.hero p.lead{font-size:clamp(1.05rem,2.2vw,1.4rem);max-width:46ch;margin:20px 0 34px;font-weight:600;text-shadow:0 2px 14px rgba(13,74,145,.5)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;color:#fff;font-family:var(--display);font-size:.8rem;letter-spacing:2px;text-align:center;opacity:.9;animation:bob 2s ease-in-out infinite}
.scroll-hint svg{margin:6px auto 0}

.float{position:absolute;z-index:1;will-change:transform}
.balloon{width:70px;height:88px;border-radius:50% 50% 48% 48%;position:relative;box-shadow:inset -8px -8px 18px rgba(0,0,0,.12)}
.balloon::after{content:"";position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:9px solid currentColor;opacity:.85}
.cloud{width:130px;height:46px;background:rgba(255,255,255,.85);border-radius:40px;filter:blur(.3px)}
.cloud::before,.cloud::after{content:"";position:absolute;background:rgba(255,255,255,.85);border-radius:50%}
.cloud::before{width:60px;height:60px;top:-26px;left:18px}
.cloud::after{width:44px;height:44px;top:-18px;left:64px}
@keyframes drift{0%{transform:translateY(0) translateX(0)}50%{transform:translateY(-26px) translateX(14px)}100%{transform:translateY(0) translateX(0)}}
@keyframes driftSlow{0%{transform:translateX(0)}100%{transform:translateX(120px)}}
@keyframes wiggle{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- Trust strip ---------- */
.trust{background:var(--navy);color:#fff;padding:22px 0}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 42px}
.trust b{font-family:var(--display);display:flex;align-items:center;gap:10px;font-weight:500;font-size:1.05rem}
.trust b svg{flex:none}

/* ---------- Section heading ---------- */
.sec-head{text-align:center;max-width:640px;margin:0 auto 54px}
.sec-tag{font-family:var(--display);font-weight:600;color:var(--red);letter-spacing:2px;text-transform:uppercase;font-size:.86rem}
.sec-head h2{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:700;color:var(--navy);margin:8px 0 12px}
.sec-head p{font-size:1.08rem;color:#4a5a73}

/* ---------- Inflatables ---------- */
.inflatables{padding:96px 0 90px;background:radial-gradient(circle at 12% 0%,rgba(246,185,22,.14),transparent 38%),radial-gradient(circle at 90% 100%,rgba(21,101,192,.12),transparent 40%),var(--cream)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:30px}
.card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(13,74,145,.06);display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s}
.card:hover{transform:translateY(-10px) rotate(-.5deg);box-shadow:0 30px 50px -22px rgba(13,74,145,.55)}
.card-img{aspect-ratio:4/3;position:relative;display:flex;align-items:flex-end;padding:14px;overflow:hidden}
.card-img .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.card-img .price{margin-left:auto;background:#fff;color:var(--navy);font-family:var(--display);font-weight:700;padding:8px 14px;border-radius:999px;box-shadow:var(--shadow-sm);font-size:1.05rem;z-index:2}
.card-img .price small{display:block;font-size:.62rem;font-weight:600;color:#7a879b;letter-spacing:.5px}
.card-img .tag{position:absolute;top:14px;left:14px;z-index:2;background:var(--yellow);color:var(--navy);font-family:var(--display);font-weight:600;font-size:.74rem;padding:5px 12px;border-radius:999px;letter-spacing:.5px}
.card-img .scene{position:absolute;inset:0;z-index:0}
.card-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.45rem;font-weight:600;color:var(--navy)}
.card-body .desc{color:#5a6884;font-size:.97rem;margin:8px 0 16px;flex:1}
.specs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.spec{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:500;font-size:.82rem;background:#f1f6fd;color:var(--blue-deep);padding:6px 11px;border-radius:999px}
.card .btn{width:100%;justify-content:center}

/* ---------- Why us ---------- */
.why{padding:30px 0 96px;background:var(--cream)}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:26px}
.feature{text-align:center;padding:8px}
.feature .ico{width:84px;height:84px;margin:0 auto 16px;border-radius:24px;display:grid;place-items:center;box-shadow:var(--shadow-sm);transform:rotate(-4deg);transition:transform .3s}
.feature:hover .ico{transform:rotate(4deg) scale(1.05)}
.feature h3{font-size:1.25rem;font-weight:600;color:var(--navy);margin-bottom:6px}
.feature p{color:#5a6884;font-size:.97rem}

/* ---------- Contact ---------- */
.contact{padding:96px 0;background:linear-gradient(180deg,var(--blue) 0%,var(--blue-deep) 100%);color:#fff;overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(circle at 80% -10%,rgba(246,185,22,.35),transparent 45%),radial-gradient(circle at 0% 110%,rgba(229,49,36,.35),transparent 45%)}
.contact .wrap{position:relative;z-index:2}
.contact .sec-head h2{color:#fff}
.contact .sec-head p{color:rgba(255,255,255,.85)}
.contact .sec-tag{color:var(--yellow)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:46px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:20px}
.info-card{display:flex;gap:16px;align-items:flex-start;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(6px);padding:20px 22px;border-radius:var(--r-md)}
.info-card .ico{flex:none;width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:var(--yellow);color:var(--navy)}
.info-card h4{font-size:1.12rem;font-weight:600;margin-bottom:2px}
.info-card a,.info-card p{color:rgba(255,255,255,.9);font-size:1rem}
.info-card a:hover{color:var(--yellow)}
.socials{display:flex;gap:12px;margin-top:4px}
.socials a{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.14);transition:.25s}
.socials a:hover{background:var(--yellow);color:var(--navy);transform:translateY(-3px)}

form.enquiry{background:#fff;border-radius:var(--r-lg);padding:32px;box-shadow:0 30px 60px -28px rgba(0,0,0,.5)}
form.enquiry .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--display);font-weight:500;color:var(--navy);font-size:.92rem;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;font-family:var(--body);font-size:1rem;color:var(--navy);padding:12px 14px;border:2px solid #e4ecf6;border-radius:var(--r-sm);background:#fafcff;transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(21,101,192,.12)}
.field textarea{resize:vertical;min-height:110px}
form.enquiry .btn{width:100%;justify-content:center;font-size:1.1rem;margin-top:4px}
.form-note{text-align:center;font-size:.85rem;color:#7a879b;margin-top:12px}
.form-feedback{text-align:center;font-family:var(--display);font-weight:500;margin-top:14px;display:none}
.form-feedback.show{display:block}
.form-feedback.ok{color:#2e9e57}
.form-feedback.err{color:var(--red)}

/* ---------- Footer ---------- */
footer.site-footer{background:var(--navy);color:rgba(255,255,255,.7);text-align:center;padding:34px 0}
footer.site-footer .brand{justify-content:center;margin-bottom:14px}
footer.site-footer .brand-text b,footer.site-footer .brand-text .tag{color:#fff}
footer.site-footer .fnav{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-bottom:16px;font-family:var(--display)}
footer.site-footer .fnav a:hover{color:var(--yellow)}
footer.site-footer small{font-size:.85rem}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .contact-grid{grid-template-columns:1fr}
  .nav-toggle{display:block;z-index:60}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(320px,80vw);background:var(--white);flex-direction:column;justify-content:center;gap:30px;padding:40px;transform:translateX(100%);transition:transform .35s cubic-bezier(.22,1,.36,1);box-shadow:-20px 0 50px -20px rgba(0,0,0,.4)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a.link{color:var(--navy)!important;text-shadow:none!important;font-size:1.3rem}
  header.nav:not(.scrolled) .nav-links a.link{color:var(--navy)!important;text-shadow:none!important}
}
@media(max-width:540px){
  form.enquiry{padding:22px}
  form.enquiry .row{grid-template-columns:1fr}
  .hero .wrap{padding:110px 0 80px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}
