/* Urban Reads — shared design system */
:root{
  /* Urban Reads FOUNDATION palette — blue primary, pink + gold accents, navy ink.
     NOTE: legacy class names band-green/btn-green now render BLUE, band-red/btn-red render PINK. */
  --black:#0e2a39;--ink:#15384b;
  --red:#ec0a64;--red-d:#c40b56;      /* pink */
  --green:#28b6e6;--green-d:#1488b8;  /* blue */
  --gold:#fcb400;--sun:#ffd24d;--gold-d:#d39400;
  --sky:#5cc4ec;--navy:#00497a;--blue-deep:#0a4d72;
  --cream:#eef9fe;--paper:#ffffff;--peach:#d8eef9;
  --gray:#5d7280;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Nunito',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;font-weight:600;overflow-x:hidden}
h1,h2,h3,h4,.display{font-family:'Fredoka',sans-serif;font-weight:700;line-height:1.04;letter-spacing:-.01em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.center{text-align:center}
.kick{font-family:'Fredoka';font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.86rem;color:var(--red)}
.section{padding:74px 0}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Fredoka';font-weight:700;font-size:1.05rem;padding:15px 30px;border-radius:100px;border:none;cursor:pointer;transition:transform .15s,box-shadow .2s}
.btn-red{background:var(--red);color:#fff;box-shadow:0 8px 0 var(--red-d)}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 12px 0 var(--red-d)}
.btn-green{background:var(--green);color:#fff;box-shadow:0 8px 0 var(--green-d)}
.btn-green:hover{transform:translateY(-2px);box-shadow:0 12px 0 var(--green-d)}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:0 8px 0 var(--gold-d)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 0 var(--gold-d)}
.btn-cream{background:#fff;color:var(--blue-deep);box-shadow:0 8px 0 #cfeaf6}
.btn-cream:hover{transform:translateY(-2px)}
.btn-line{background:transparent;color:#fff;border:2.5px solid rgba(255,255,255,.7)}
.btn-line:hover{background:rgba(255,255,255,.15)}

/* topbar + nav (injected by site.js) */
.topbar{background:var(--green);color:#fff;text-align:center;font-family:'Fredoka';font-weight:600;font-size:.92rem;padding:10px}
.topbar a{color:var(--sun)}
header.nav{position:sticky;top:0;z-index:60;background:rgba(255,253,246,.95);backdrop-filter:blur(8px);border-bottom:3px solid var(--peach)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:80px}
.nav .brand img{height:66px}
.nav .links{display:flex;gap:22px;align-items:center}
.nav .links a{font-family:'Fredoka';font-weight:500;color:var(--ink);font-size:1rem}
.nav .links a:hover,.nav .links a.active{color:var(--red)}
.nav .links a.active{font-weight:600}
.navtoggle{display:none;background:none;border:none;font-size:1.7rem;line-height:1;cursor:pointer;color:var(--ink);padding:4px 8px;align-items:center}
/* install app button + iOS tip (injected by site.js) */
#install{display:none;position:fixed;bottom:16px;left:16px;z-index:95;background:#fff;border:3px solid var(--green);border-radius:14px;padding:11px 14px;box-shadow:6px 7px 0 var(--green-d);align-items:center;gap:10px;max-width:calc(100vw - 32px)}
#install b{font-family:'Fredoka';color:var(--black)}
#install .x{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--ink);padding:0 2px;line-height:1}
#iostip{display:none;position:fixed;bottom:78px;left:16px;z-index:95;background:#fff;border:3px solid var(--green);border-radius:14px;padding:14px 16px;max-width:300px;box-shadow:6px 7px 0 var(--green-d);font-weight:700;font-size:.92rem;color:var(--ink)}
#iostip.on{display:block}
#iostip .shareicon{display:inline-block;font-weight:900;color:var(--green-d)}

/* hero variants */
.hero-photo{position:relative;min-height:clamp(440px,62vh,640px);display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-photo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 32%}
.hero-photo .wash{position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,182,230,.38) 0,rgba(0,0,0,.05) 30%,rgba(10,42,58,.45) 62%,rgba(10,42,58,.93) 100%)}
.hero-photo .wrap{position:relative;z-index:3;padding:48px 26px}
.hero-photo h1{font-size:clamp(2.4rem,6vw,4.4rem);text-transform:uppercase}
.hero-photo h1 .y{color:var(--sun)}.hero-photo h1 .r{color:#ff7eb0}
.hero-photo p{font-size:1.18rem;max-width:560px;margin:16px 0 24px;color:#eef9ff;font-weight:600}
.hero-photo .flagbar,.flagbar{height:8px;background:linear-gradient(90deg,var(--red) 0 33%,#111 33% 66%,var(--green) 66% 100%)}
.hero-photo .flagbar{position:absolute;left:0;right:0;bottom:0;z-index:4}
.pagehead{background:var(--ink);color:#fff;text-align:center;padding:60px 0;position:relative;overflow:hidden}
.pagehead .flagbar{position:absolute;left:0;right:0;bottom:0}
.pagehead .kick{color:var(--sun)}
.pagehead h1{font-size:clamp(2.2rem,5.4vw,3.6rem);text-transform:uppercase;margin:10px 0}
.pagehead p{color:#dceefa;max-width:640px;margin:0 auto;font-size:1.12rem}

.pill{display:inline-flex;align-items:center;gap:8px;background:var(--sun);color:#5a3d00;font-family:'Fredoka';font-weight:600;padding:8px 16px;border-radius:100px;font-size:.9rem;margin-bottom:16px}

/* section heads */
.head{text-align:center;max-width:700px;margin:0 auto 40px}
.head h2{font-size:clamp(2rem,4.6vw,3rem);color:var(--ink);margin:8px 0 10px;text-transform:uppercase}
.head p{color:#5d7280;font-size:1.1rem}
.band-green{background:var(--green);color:#fff}
.band-red{background:var(--red);color:#fff}
.band-cream{background:var(--cream)}
.band-green .head h2,.band-red .head h2{color:#fff}
.band-green .head p,.band-red .head p{color:rgba(255,255,255,.92)}

/* ticker */
.ticker{background:var(--gold);color:var(--ink);overflow:hidden;border-top:4px solid var(--ink);border-bottom:4px solid var(--ink)}
.ticker .r{display:flex;white-space:nowrap;font-family:'Fredoka';font-weight:700;font-size:1.3rem;text-transform:uppercase;padding:13px 0;animation:scroll 26s linear infinite}
.ticker .r span{padding:0 22px}.ticker .r span::after{content:"★";color:var(--red);margin-left:22px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* stat cards */
.statgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.stat{border-radius:20px;padding:26px 14px;text-align:center;color:#fff;background:var(--c);box-shadow:0 12px 0 var(--cd)}
.stat .n{font-family:'Fredoka';font-weight:700;font-size:2.3rem;line-height:1}
.stat .l{font-weight:700;font-size:.86rem;margin-top:6px;opacity:.96}

/* zigzag pictures */
.zz{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;margin-bottom:34px}
.zz:last-child{margin-bottom:0}
.zz.flip .txt{order:2}
.zz .frame{border-radius:26px;overflow:hidden;border:7px solid #fff;box-shadow:0 18px 40px -22px rgba(10,77,114,.4);aspect-ratio:5/4}
.zz .frame img{width:100%;height:100%;object-fit:cover}
.zz .tagp{display:inline-block;font-family:'Fredoka';font-weight:600;font-size:.84rem;text-transform:uppercase;color:#fff;background:var(--red);padding:6px 14px;border-radius:100px;margin-bottom:12px}
.zz .tagp.g{background:var(--green)}
.zz h3{font-size:clamp(1.7rem,3.4vw,2.2rem);text-transform:uppercase;color:var(--ink);margin-bottom:10px}
.zz p{color:#5d7280;font-size:1.08rem;font-weight:600}

/* slideshow */
.slideshow{position:relative;border-radius:28px;overflow:hidden;border:7px solid var(--cream);box-shadow:0 20px 44px -22px rgba(10,77,114,.4);aspect-ratio:4/3;background:#000}
.slides{position:relative;width:100%;height:100%}
.slides img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .7s}
.slides img.on{opacity:1}
.dots{position:absolute;bottom:14px;left:0;right:0;display:flex;gap:8px;justify-content:center;z-index:3}
.dots b{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.55);cursor:pointer}
.dots b.on{background:var(--sun)}
.arw{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;display:grid;place-items:center;cursor:pointer;z-index:3;font-size:1.3rem;border:none}
.arw.l{left:12px}.arw.r{right:12px}

/* video */
.video{position:relative;max-width:880px;margin:0 auto;border-radius:24px;overflow:hidden;border:7px solid var(--green);box-shadow:0 22px 46px -24px rgba(0,0,0,.45);background:#000;aspect-ratio:16/9}
.video video{width:100%;height:100%;object-fit:cover;display:block}

/* chips */
.chips{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0 22px}
.chip{background:var(--cream);border-radius:100px;padding:9px 16px;font-family:'Fredoka';font-weight:600;font-size:.9rem;color:var(--ink)}

/* quote */
.quoteband{background:var(--green);color:#fff;padding:54px 0;text-align:center}
.quoteband blockquote{font-family:'Fredoka';font-weight:600;font-size:clamp(1.5rem,3.4vw,2.3rem);line-height:1.2;max-width:900px;margin:0 auto}
.quoteband .who{margin-top:18px;font-family:'Fredoka';font-weight:600;color:var(--sun)}
.quoteband .who small{display:block;color:#d6f3fc;font-family:'Nunito';font-weight:700;margin-top:3px}

/* plans */
.onetime{max-width:880px;margin:0 auto 40px;background:#fff;border:3px dashed var(--gold);border-radius:24px;padding:24px 28px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}
.onetime .t{font-family:'Fredoka';font-weight:600;font-size:1.25rem;color:var(--ink)}
.onetime .t small{display:block;font-family:'Nunito';font-weight:700;color:var(--gray);font-size:.92rem}
.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.plan{background:#fff;border-radius:22px;border:3px solid var(--peach);padding:22px 20px;display:flex;flex-direction:column;transition:transform .15s}
.plan:hover{transform:translateY(-5px)}
.plan.fav{border-color:var(--gold);box-shadow:0 16px 36px -22px rgba(244,178,35,.7);position:relative}
.plan .rib{position:absolute;top:-12px;right:14px;background:var(--gold);color:#5a3d00;font-family:'Fredoka';font-weight:600;font-size:.72rem;text-transform:uppercase;padding:4px 12px;border-radius:100px}
.plan .nm{font-family:'Fredoka';font-weight:600;font-size:1.12rem;color:var(--ink);line-height:1.1;min-height:2.2em}
.plan .pr{font-family:'Fredoka';font-weight:700;font-size:2rem;color:var(--red);margin:4px 0 2px}
.plan .pr small{font-size:.85rem;color:var(--gray);font-weight:700}
.plan .fn{color:#5d7280;font-size:.88rem;font-weight:600;margin:6px 0 16px;flex:1}
.plan .btn{justify-content:center;width:100%;font-size:.92rem;padding:12px}

/* generic card grid */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.card{background:#fff;border-radius:22px;border:3px solid var(--peach);padding:26px;box-shadow:0 14px 30px -24px rgba(0,0,0,.3)}
.card h3{font-size:1.35rem;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.card .ic{font-size:2rem;margin-bottom:8px}
.card p{color:#5d7280;font-weight:600}

/* form */
.form{max-width:680px;margin:0 auto;background:#fff;border:3px solid var(--peach);border-radius:24px;padding:34px}
.form label{display:block;font-family:'Fredoka';font-weight:600;margin:14px 0 6px;color:var(--ink)}
.form input,.form select,.form textarea{width:100%;padding:13px 15px;border:2px solid var(--peach);border-radius:12px;font-family:'Nunito';font-weight:600;font-size:1rem;background:var(--paper)}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--green)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form .btn{width:100%;justify-content:center;margin-top:22px}

/* footer (injected) */
footer.site{background:var(--navy);color:#cfe3ef;padding:50px 0 28px;font-weight:700}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;align-items:start}
footer.site img.flogo{height:50px;margin-bottom:14px}
footer.site .cols p{color:#a9c6d8;font-weight:600}
footer.site h4{font-family:'Fredoka';color:#fff;text-transform:uppercase;font-size:1rem;margin-bottom:12px}
footer.site .cols a{display:block;color:#cfe3ef;padding:4px 0;font-weight:600}
footer.site .cols a:hover{color:var(--sun)}
footer.site small{display:block;text-align:center;color:#7ea6c0;margin-top:34px;border-top:1px solid rgba(255,255,255,.12);padding-top:20px}

@media(max-width:880px){
  .navtoggle{display:flex}
  .nav .wrap{flex-wrap:wrap;height:auto;min-height:74px}
  .nav .links{display:none;order:5;flex-basis:100%;flex-direction:column;align-items:stretch;gap:0;padding:6px 0 10px}
  .nav>.wrap>.btn-red{display:none}
  header.nav.open .links{display:flex}
  header.nav.open>.wrap>.btn-red{display:inline-flex;order:6;flex-basis:100%;justify-content:center;margin-top:6px}
  .nav .links a{padding:13px 4px;border-top:2px solid var(--peach);font-size:1.05rem}
  .statgrid{grid-template-columns:repeat(2,1fr)}
  .zz{grid-template-columns:1fr}.zz.flip .txt{order:0}
  .plans,.grid3{grid-template-columns:repeat(2,1fr)}
  .grid2,.form .row,footer.site .cols{grid-template-columns:1fr}
}

/* sponsors strip */
.sponsors{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:940px;margin:0 auto}
.slogo{background:#fff;border:3px solid var(--peach);border-radius:18px;height:118px;display:grid;place-items:center;padding:16px;transition:transform .15s,box-shadow .2s}
.slogo:hover{transform:translateY(-4px);box-shadow:0 14px 30px -22px rgba(0,0,0,.4)}
.slogo img{max-height:78px;max-width:100%;object-fit:contain}
@media(max-width:680px){.sponsors{grid-template-columns:repeat(2,1fr)}}

/* ===== kid-friendly graphics pass ===== */
/* hand-drawn squiggle underline under section headings */
.head h2::after{content:"";display:block;width:120px;height:13px;margin:10px auto 0;background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='13'%3E%3Cpath d='M3 8 Q18 1 33 8 T63 8 T93 8 T117 8' fill='none' stroke='%23f4b223' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E")}
.band-green .head h2::after,.band-red .head h2::after,.pagehead h1::after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='13'%3E%3Cpath d='M3 8 Q18 1 33 8 T63 8 T93 8 T117 8' fill='none' stroke='%23ffd54a' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E")}
.pagehead h1::after{content:"";display:block;width:130px;height:13px;margin:14px auto 0;background:center/contain no-repeat}
/* gentle dot texture on color bands */
.band-cream{background-color:var(--cream);background-image:radial-gradient(rgba(226,59,57,.10) 2.2px,transparent 2.2px);background-size:28px 28px}
.band-green{background-image:radial-gradient(rgba(255,255,255,.08) 2.2px,transparent 2.2px);background-size:28px 28px}
.band-red{background-image:radial-gradient(rgba(255,255,255,.09) 2.2px,transparent 2.2px);background-size:28px 28px}
/* floating doodles in heroes */
@keyframes floatdd{0%,100%{transform:translateY(0) rotate(-8deg)}50%{transform:translateY(-16px) rotate(8deg)}}
.hero-photo .doodles,.pagehead .doodles{position:absolute;inset:0;pointer-events:none;z-index:4;overflow:hidden}
.hero-photo .doodles b,.pagehead .doodles b{position:absolute;font-style:normal;filter:drop-shadow(0 6px 10px rgba(0,0,0,.35));animation:floatdd 7s ease-in-out infinite}
.doodles .d1{top:14%;right:7%;font-size:2.6rem;animation-delay:.2s}
.doodles .d2{top:30%;right:20%;font-size:1.7rem;animation-delay:1.3s}
.doodles .d3{top:55%;right:5%;font-size:2rem;animation-delay:2.1s}
.doodles .d4{top:18%;right:33%;font-size:1.5rem;animation-delay:.8s}
@media(max-width:880px){.doodles{display:none}}
/* fix: restore gold squiggle under page-header titles */
.pagehead h1::after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='130' height='13'%3E%3Cpath d='M3 8 Q19 1 35 8 T67 8 T99 8 T127 8' fill='none' stroke='%23ffd54a' stroke-width='4' stroke-linecap='round'/%3E%3C/svg%3E")}

/* ===== voices: bus sticker artwork ===== */
.voicesband{background:var(--cream);overflow:hidden;border-top:4px solid var(--ink);border-bottom:4px solid var(--ink);padding:24px 0;background-image:radial-gradient(rgba(226,59,57,.09) 2.2px,transparent 2.2px);background-size:28px 28px}
.voices{display:flex;gap:34px;width:max-content;animation:vscroll 70s linear infinite}
.voicesband:hover .voices{animation-play-state:paused}
.voices img{height:235px;width:auto;flex:none;filter:drop-shadow(0 10px 16px rgba(10,77,114,.28))}
@keyframes vscroll{to{transform:translateX(-50%)}}
/* static wall grid */
.voicewall{display:grid;grid-template-columns:repeat(3,1fr);gap:26px 30px;align-items:end;justify-items:center}
.voicewall img{width:100%;max-width:340px;height:auto;filter:drop-shadow(0 12px 18px rgba(10,77,114,.24));transition:transform .2s}
.voicewall img:hover{transform:translateY(-7px) rotate(-1.5deg)}
/* ===== SHOWCASE — icon art as full design assets, bleeding across sections ===== */
.showcase{position:relative;overflow:visible}
.showcase>.wrap{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;min-height:360px;z-index:2}
.showcase .txt{grid-column:2}
.showcase.flip .txt{grid-column:1}
.showcase .txt h3{font-size:clamp(2rem,4.4vw,3rem);text-transform:uppercase;color:var(--ink);margin:6px 0 12px}
.showcase .txt p{font-size:1.14rem}
.showcase .txt{padding:8px 0}
/* height-based sizing → uniform vertical footprint regardless of portrait aspect ratio */
.showcase .fig{position:absolute;bottom:-34px;left:-7%;height:clamp(340px,37vw,500px);width:auto;max-width:50%;z-index:7;filter:drop-shadow(0 30px 26px rgba(0,0,0,.24));transition:transform .35s ease}
.showcase.flip .fig{left:auto;right:-7%}
.showcase:hover .fig{transform:translateY(-8px)}
.showcase.big .fig{left:-9%;height:clamp(400px,44vw,580px);bottom:0;max-width:52%}
.showcase.big.flip .fig{left:auto;right:-9%}
/* extra green room so a big figure can rise into it without touching the credit */
.quoteband.roomy{padding-bottom:215px}
@media(max-width:980px){.quoteband.roomy{padding-bottom:54px}}
@media(max-width:980px){
  .showcase>.wrap{display:block;min-height:0;text-align:center}
  .showcase .fig,.showcase.flip .fig,.showcase.big .fig,.showcase.big.flip .fig{position:static;display:block;height:auto;width:min(74%,340px);max-width:none;margin:0 auto 12px;bottom:auto;left:auto;right:auto}
  .showcase .txt{padding:0}
  .showcase .txt h3{font-size:clamp(1.6rem,7vw,2.4rem)}
}
