/* =========================================================
   The Toy Box — Surprise, AZ
   Self-contained stylesheet
   ========================================================= */

:root{
  --red:#e63946;
  --red-light:#ff5a5f;
  --yellow:#ffce3a;
  --yellow-light:#ffd84d;
  --blue:#3aa8e0;
  --blue-light:#57c1f0;
  --green:#4cae57;
  --cream:#fffdf7;
  --cream-2:#fff7e6;
  --ink:#2b2440;
  --ink-soft:#5b5470;
  --white:#ffffff;
  --shadow-sm:0 4px 14px rgba(43,36,64,.10);
  --shadow-md:0 14px 36px rgba(43,36,64,.14);
  --shadow-lg:0 24px 60px rgba(43,36,64,.20);
  --radius:18px;
  --radius-lg:28px;
  --maxw:1180px;
  --font-display:"Fredoka","Baloo 2",system-ui,sans-serif;
  --font-body:"Nunito","Quicksand",system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;font-weight:600;color:var(--ink)}
section{position:relative}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{
  display:inline-block;font-family:var(--font-display);font-weight:600;
  letter-spacing:.5px;text-transform:uppercase;font-size:.78rem;
  color:var(--red);background:#ffe3e4;padding:6px 14px;border-radius:999px;margin-bottom:14px;
}
.section{padding:84px 0}
.section-head{max-width:680px;margin:0 auto 50px;text-align:center}
.section-head h2{font-size:clamp(1.9rem,4vw,2.9rem)}
.section-head p{color:var(--ink-soft);font-size:1.08rem;margin-top:14px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:none;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  padding:14px 26px;border-radius:999px;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.btn:active{transform:translateY(-1px)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{filter:brightness(1.05)}
.btn-secondary{background:var(--yellow);color:var(--ink)}
.btn-ghost{background:#fff;color:var(--ink);border:2px solid #ffe1c4}
.btn-blue{background:var(--blue);color:#fff}
.btn svg{width:20px;height:20px}

/* =========================================================
   Intro animation
   ========================================================= */
.intro{
  position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 38%,#fff7df 0%,#ffe9c9 45%,#ffd6a6 100%);
  transition:opacity .55s ease,visibility .55s ease;
}
.intro.hide{opacity:0;visibility:hidden;pointer-events:none}
.intro-stage{position:relative;width:340px;height:300px;max-width:88vw}
.intro-skip{
  position:absolute;top:22px;right:22px;background:#fff;color:var(--ink);
  border:2px solid #ffd9b0;border-radius:999px;padding:9px 20px;font-family:var(--font-display);
  font-weight:600;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .15s ease;
}
.intro-skip:hover{transform:scale(1.05)}

/* the box */
.box{position:absolute;left:50%;bottom:48px;transform:translateX(-50%);width:190px;height:120px}
.box-body{
  position:absolute;bottom:0;width:190px;height:104px;border-radius:10px;
  background:linear-gradient(180deg,#ff7378,#e63946);box-shadow:var(--shadow-md);
}
.box-body::after{content:"";position:absolute;inset:0;border-radius:10px;
  background:repeating-linear-gradient(90deg,transparent 0 26px,rgba(255,255,255,.12) 26px 30px)}
.box-lid{
  position:absolute;top:-14px;left:-6px;width:202px;height:30px;border-radius:9px;
  background:linear-gradient(180deg,#ffd84d,#ffce3a);transform-origin:left bottom;
  box-shadow:var(--shadow-sm);animation:lidOpen .7s .25s cubic-bezier(.6,-0.4,.3,1.4) forwards;
}
@keyframes lidOpen{0%{transform:rotate(0)}100%{transform:rotate(-118deg)}}

/* toys tumbling */
.toy{position:absolute;left:50%;bottom:120px;opacity:0;transform:translateX(-50%)}
.toy svg{width:46px;height:46px;display:block}
.toy.t1{animation:tumble1 1.1s .45s cubic-bezier(.4,1.4,.5,1) forwards}
.toy.t2{animation:tumble2 1.1s .58s cubic-bezier(.4,1.4,.5,1) forwards}
.toy.t3{animation:tumble3 1.1s .70s cubic-bezier(.4,1.4,.5,1) forwards}
.toy.t4{animation:tumble4 1.1s .82s cubic-bezier(.4,1.4,.5,1) forwards}
@keyframes tumble1{0%{opacity:0;transform:translate(-50%,10px) rotate(0)}30%{opacity:1}100%{opacity:1;transform:translate(-160px,40px) rotate(-340deg)}}
@keyframes tumble2{0%{opacity:0;transform:translate(-50%,10px) rotate(0)}30%{opacity:1}100%{opacity:1;transform:translate(-70px,8px) rotate(280deg)}}
@keyframes tumble3{0%{opacity:0;transform:translate(-50%,10px) rotate(0)}30%{opacity:1}100%{opacity:1;transform:translate(60px,12px) rotate(-260deg)}}
@keyframes tumble4{0%{opacity:0;transform:translate(-50%,10px) rotate(0)}30%{opacity:1}100%{opacity:1;transform:translate(150px,44px) rotate(320deg)}}

.intro-word{
  position:absolute;left:0;right:0;top:8px;text-align:center;
  font-family:var(--font-display);font-weight:600;font-size:2.2rem;letter-spacing:.5px;
  opacity:0;transform:translateY(12px) scale(.9);
  animation:wordIn .6s 1.35s ease forwards;
}
.intro-word .a{color:var(--red)}
.intro-word .b{color:var(--blue)}
.intro-word .c{color:var(--green)}
@keyframes wordIn{to{opacity:1;transform:translateY(0) scale(1)}}

/* =========================================================
   Header
   ========================================================= */
.header{
  position:sticky;top:0;z-index:900;background:rgba(255,253,247,.86);
  backdrop-filter:blur(10px);border-bottom:2px solid #ffe9cf;transition:box-shadow .25s ease;
}
.header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:1.32rem}
.brand .mark{width:40px;height:40px;flex:none}
.brand .a{color:var(--red)}
.brand .b{color:var(--blue)}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{font-weight:700;color:var(--ink-soft);transition:color .15s ease;position:relative}
.nav-links a:hover{color:var(--red)}
.nav-links .btn{color:#fff}
.nav-toggle{display:none}

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;overflow:hidden;padding:70px 0 90px;
  background:
    radial-gradient(circle at 14% 18%,rgba(255,206,58,.30),transparent 38%),
    radial-gradient(circle at 88% 14%,rgba(58,168,224,.26),transparent 40%),
    radial-gradient(circle at 70% 92%,rgba(76,174,87,.20),transparent 44%),
    var(--cream);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(2.3rem,5.4vw,4rem)}
.hero h1 .pop{color:var(--red);position:relative;white-space:nowrap}
.hero-sub{font-size:1.18rem;color:var(--ink-soft);margin:20px 0 28px;max-width:540px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.trust-line{display:flex;align-items:center;gap:10px;margin-top:24px;color:var(--ink-soft);font-weight:700;font-size:.96rem}
.trust-line svg{width:20px;height:20px;color:var(--green);flex:none}

/* hero illustration */
.hero-art{position:relative;aspect-ratio:1/1;max-width:460px;margin:0 auto;width:100%}
.blob{position:absolute;inset:0;z-index:0}
.float{position:absolute;animation:bob 4s ease-in-out infinite}
.float:nth-child(3){animation-delay:.6s}
.float:nth-child(4){animation-delay:1.1s}
.float:nth-child(5){animation-delay:1.6s}
@keyframes bob{0%,100%{transform:translateY(0) rotate(var(--r,0))}50%{transform:translateY(-14px) rotate(var(--r,0))}}

/* =========================================================
   Trust bar
   ========================================================= */
.trustbar{background:var(--ink);color:#fff;padding:20px 0}
.trustbar .row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 38px;align-items:center}
.trustbar .item{display:flex;align-items:center;gap:10px;font-weight:700;font-size:.98rem}
.trustbar .item svg{width:22px;height:22px;flex:none}
.trustbar .c-y{color:var(--yellow)}
.trustbar .c-b{color:var(--blue-light)}
.trustbar .c-g{color:#7fe08b}
.trustbar .c-r{color:var(--red-light)}

/* =========================================================
   Services grid
   ========================================================= */
.services{background:var(--cream)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:#fff;border-radius:var(--radius-lg);padding:30px 26px;border:2px solid #f3ead9;
  box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:#ffe1c4}
.card .ico{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;margin-bottom:16px}
.card .ico svg{width:32px;height:32px;color:#fff}
.ico.r{background:var(--red)}.ico.y{background:var(--yellow)}.ico.b{background:var(--blue)}
.ico.g{background:var(--green)}.ico.p{background:#a06cd5}.ico.o{background:#ff8e3c}
.ico.y svg{color:var(--ink)}
.card h3{font-size:1.28rem;margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:.98rem}

/* =========================================================
   Why us
   ========================================================= */
.why{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.why-list{display:grid;gap:18px;margin-top:24px}
.why-item{display:flex;gap:16px;align-items:flex-start}
.why-item .dot{width:46px;height:46px;border-radius:13px;flex:none;display:grid;place-items:center}
.why-item .dot svg{width:24px;height:24px;color:#fff}
.why-item h4{font-size:1.12rem;margin-bottom:3px}
.why-item p{color:var(--ink-soft);font-size:.96rem}
.why-figure{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:30px;border:2px solid #f3ead9}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.stat{background:var(--cream-2);border-radius:var(--radius);padding:22px;text-align:center}
.stat .n{font-family:var(--font-display);font-weight:700;font-size:2rem;color:var(--red)}
.stat:nth-child(2) .n{color:var(--blue)}
.stat:nth-child(3) .n{color:var(--green)}
.stat:nth-child(4) .n{color:#ff8e3c}
.stat .l{font-weight:700;color:var(--ink-soft);font-size:.9rem;margin-top:4px}

/* =========================================================
   Showcase (CSS/SVG toy shelf scene)
   ========================================================= */
.showcase{background:var(--blue);color:#fff;overflow:hidden}
.showcase .section-head h2{color:#fff}
.showcase .section-head p{color:rgba(255,255,255,.9)}
.shelf-scene{
  background:linear-gradient(180deg,#fff6e0,#ffe9c4);border-radius:var(--radius-lg);
  padding:30px 26px;box-shadow:var(--shadow-lg);max-width:920px;margin:0 auto;
}
.shelf{position:relative;padding:18px 16px 26px;margin-bottom:14px}
.shelf:last-child{margin-bottom:0}
.shelf-board{position:absolute;left:0;right:0;bottom:0;height:16px;border-radius:8px;
  background:linear-gradient(180deg,#c98a4b,#a9703a);box-shadow:0 6px 0 rgba(0,0,0,.08)}
.shelf-row{position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:space-around;gap:12px;flex-wrap:wrap}
.toy-item{display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .2s ease}
.toy-item:hover{transform:translateY(-8px) rotate(-3deg)}
.toy-item svg{width:64px;height:64px}
.toy-item span{font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--ink)}

/* =========================================================
   Testimonials
   ========================================================= */
.reviews{background:var(--cream)}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{
  background:#fff;border-radius:var(--radius-lg);padding:28px;border:2px solid #f3ead9;
  box-shadow:var(--shadow-sm);position:relative;
}
.quote .mark{font-family:var(--font-display);font-size:3.4rem;line-height:.6;color:var(--yellow);position:absolute;top:18px;right:22px}
.quote p{font-size:1.02rem;color:var(--ink);position:relative;z-index:2}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:18px}
.quote .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700}
.quote .who b{font-family:var(--font-display)}
.quote .who small{display:block;color:var(--ink-soft);font-weight:700}

/* =========================================================
   FAQ
   ========================================================= */
.faq{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.faq-list{max-width:760px;margin:0 auto;display:grid;gap:14px}
.faq-item{background:#fff;border:2px solid #f3ead9;border-radius:var(--radius);overflow:hidden;transition:border-color .2s ease}
.faq-item[open]{border-color:#ffd9b0}
.faq-item summary{
  list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--font-display);font-weight:600;
  font-size:1.08rem;display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .plus{flex:none;width:28px;height:28px;border-radius:50%;background:var(--yellow);
  display:grid;place-items:center;font-size:1.3rem;transition:transform .2s ease;color:var(--ink)}
.faq-item[open] summary .plus{transform:rotate(45deg);background:var(--red);color:#fff}
.faq-item .ans{padding:0 24px 22px;color:var(--ink-soft)}

/* =========================================================
   CTA band
   ========================================================= */
.ctaband{
  background:linear-gradient(120deg,var(--red),#ff7a5a 55%,var(--yellow));color:#fff;text-align:center;
  border-radius:0;padding:74px 0;overflow:hidden;position:relative;
}
.ctaband h2{color:#fff;font-size:clamp(2rem,4.5vw,3.1rem)}
.ctaband p{font-size:1.15rem;margin:14px auto 28px;max-width:560px;color:rgba(255,255,255,.95)}
.ctaband .hero-cta{justify-content:center}
.ctaband .btn-primary{background:#fff;color:var(--red)}
.ctaband .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}

/* =========================================================
   Contact
   ========================================================= */
.contact{background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:stretch}
.contact-card{background:#fff;border-radius:var(--radius-lg);padding:34px;border:2px solid #f3ead9;box-shadow:var(--shadow-sm)}
.contact-line{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.contact-line .ico{width:48px;height:48px;border-radius:13px;flex:none;display:grid;place-items:center}
.contact-line .ico svg{width:24px;height:24px;color:#fff}
.contact-line b{font-family:var(--font-display);display:block;font-size:1.05rem}
.contact-line a,.contact-line span{color:var(--ink-soft);font-weight:700}
.contact-line a:hover{color:var(--red)}
.hours-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed #eadfc8;font-weight:700}
.hours-row:last-child{border-bottom:none}
.hours-row span:last-child{color:var(--ink-soft)}
.map-faux{
  border-radius:var(--radius-lg);min-height:340px;border:2px solid #f3ead9;box-shadow:var(--shadow-sm);
  background:
    linear-gradient(rgba(76,174,87,.10),rgba(58,168,224,.10)),
    repeating-linear-gradient(0deg,#eef6ec 0 28px,#e6f0e4 28px 30px),
    repeating-linear-gradient(90deg,#eef6ec 0 28px,#e6f0e4 28px 30px);
  position:relative;display:grid;place-items:center;text-align:center;overflow:hidden;
}
.map-faux .pin{display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.map-faux .pin svg{width:46px;height:46px;color:var(--red);filter:drop-shadow(0 6px 8px rgba(0,0,0,.18))}
.map-faux .pin b{font-family:var(--font-display);background:#fff;padding:6px 14px;border-radius:999px;box-shadow:var(--shadow-sm)}
.map-faux .road{position:absolute;background:#fff;opacity:.8}
.map-faux .road.h{height:14px;left:-5%;right:-5%;top:46%;transform:rotate(-4deg)}
.map-faux .road.v{width:14px;top:-5%;bottom:-5%;left:62%}

/* =========================================================
   Footer
   ========================================================= */
.footer{background:var(--ink);color:rgba(255,255,255,.82);padding:54px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:34px}
.footer .brand{color:#fff;margin-bottom:14px}
.footer p{font-size:.96rem;max-width:340px}
.footer h5{font-family:var(--font-display);color:#fff;font-size:1.05rem;margin-bottom:14px}
.footer ul{list-style:none;display:grid;gap:9px}
.footer ul a{color:rgba(255,255,255,.78);font-weight:700;transition:color .15s ease}
.footer ul a:hover{color:var(--yellow)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);padding-top:22px;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:.9rem}
.footer-bottom a{color:var(--yellow);font-weight:700}

/* =========================================================
   Mobile sticky call/visit bar
   ========================================================= */
.mobilebar{
  position:fixed;left:0;right:0;bottom:0;z-index:850;display:none;
  grid-template-columns:1fr 1fr;gap:1px;background:#ffe1c4;
  box-shadow:0 -8px 24px rgba(43,36,64,.16);
}
.mobilebar a{
  display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 8px;
  font-family:var(--font-display);font-weight:600;color:#fff;font-size:1rem;
}
.mobilebar a svg{width:20px;height:20px}
.mobilebar .call{background:var(--red)}
.mobilebar .visit{background:var(--blue)}

/* =========================================================
   Scroll reveal
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.40s}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-art{max-width:360px}
  .why-grid{grid-template-columns:1fr;gap:34px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .quotes{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-links{
    position:absolute;top:70px;left:0;right:0;background:var(--cream);flex-direction:column;
    align-items:stretch;gap:0;padding:8px 22px 18px;border-bottom:2px solid #ffe9cf;
    box-shadow:var(--shadow-md);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s ease;
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:13px 4px;border-bottom:1px solid #ffe9cf}
  .nav-links .btn{margin-top:10px;justify-content:center}
  .nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
  .nav-toggle span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.2s}
  .mobilebar{display:grid}
  body{padding-bottom:56px}
  .section{padding:60px 0}
}
@media (max-width:520px){
  .cards{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-cta .btn{flex:1;justify-content:center}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .intro{display:none !important}
}
