/* TileTap Games — bespoke styles. Hand-built, intentionally unique (no framework, no template). */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --paper:#fbf3e4; --paper-2:#fff9ef; --ink:#2b2722; --ink-soft:#6b6258;
  --tomato:#ff5436; --sun:#ffb22e; --mint:#13a98f; --sky:#3d7bff; --berry:#e8497b;
  --line:#ead9bf; --dot:rgba(43,39,34,.07);
  --pop:5px 5px 0 var(--ink); --pop-sm:3px 3px 0 var(--ink);
  --r:16px; --wrap:1120px;
  --display:"Bricolage Grotesque",sans-serif; --body:"Hanken Grotesk",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);line-height:1.6;background:var(--paper);
  background-image:radial-gradient(var(--dot) 1.5px,transparent 1.5px);background-size:22px 22px;
}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--display);line-height:1.05;margin:0 0 .4em;letter-spacing:-.02em}
h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:700}
h3{font-size:1.2rem;font-weight:700}
a{color:var(--ink);text-decoration:none}
p{margin:0 0 1em}

/* header */
.site-head{position:sticky;top:0;z-index:30;background:rgba(251,243,228,.86);backdrop-filter:blur(8px);border-bottom:2px solid var(--ink)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:1.35rem}
.brand svg{display:block}
.nav{display:flex;align-items:center;gap:6px}
.nav a{font-weight:600;color:var(--ink-soft);padding:7px 13px;border-radius:10px;transition:.15s}
.nav a:hover{color:var(--ink);background:var(--sun)}
.nav .play{font-family:var(--display);font-weight:700;color:#fff;background:var(--tomato);border:2px solid var(--ink);box-shadow:var(--pop-sm);margin-left:6px}
.nav .play:hover{background:var(--tomato);color:#fff;transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}

/* buttons — chunky stickers */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:1.05rem;
  padding:14px 26px;border-radius:14px;border:2.5px solid var(--ink);cursor:pointer;transition:.12s;background:var(--sun);color:var(--ink);box-shadow:var(--pop)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.btn.tomato{background:var(--tomato);color:#fff}
.btn.ghost{background:var(--paper-2)}

/* hero */
.hero{position:relative;overflow:hidden;padding:70px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:30px;align-items:center}
.hero h1 .hl{position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.08em;height:.32em;background:var(--mint);z-index:-1;transform:rotate(-1.2deg);opacity:.55}
.hero p.lead{font-size:1.2rem;max-width:46ch;color:var(--ink-soft);font-weight:500}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-art{position:relative;height:300px}
.blob{position:absolute;border:2.5px solid var(--ink);border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:3.4rem;box-shadow:var(--pop)}
.blob.b1{width:140px;height:140px;background:var(--tomato);top:8px;left:18%;transform:rotate(-8deg);animation:bob 5s ease-in-out infinite}
.blob.b2{width:120px;height:120px;background:var(--sky);top:120px;left:54%;transform:rotate(7deg);animation:bob 6s ease-in-out infinite .4s}
.blob.b3{width:104px;height:104px;background:var(--sun);top:30px;left:62%;transform:rotate(-4deg);animation:bob 5.5s ease-in-out infinite .8s}
.blob.b4{width:96px;height:96px;background:var(--berry);top:170px;left:18%;transform:rotate(6deg);animation:bob 6.4s ease-in-out infinite .2s}
@keyframes bob{0%,100%{translate:0 0}50%{translate:0 -12px}}

/* marquee */
.marquee{border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);background:var(--ink);color:var(--paper);overflow:hidden;margin-top:34px}
.marquee div{display:inline-flex;white-space:nowrap;font-family:var(--display);font-weight:700;font-size:1.05rem;padding:11px 0;animation:slide 22s linear infinite}
.marquee span{padding:0 26px}
.marquee b{color:var(--sun)}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* sections */
section{padding:60px 0}
.sec-head{margin-bottom:34px}
.sec-head .kicker{font-family:var(--display);font-weight:700;color:var(--tomato);text-transform:uppercase;letter-spacing:.06em;font-size:.85rem;margin-bottom:4px}
.sec-head p{color:var(--ink-soft);max-width:52ch;margin:6px 0 0}

/* game cards — stickers */
.games{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:26px}
.card{position:relative;background:var(--paper-2);border:2.5px solid var(--ink);border-radius:var(--r);padding:22px;box-shadow:var(--pop);transition:.16s}
.card:nth-child(3n){transform:rotate(-1.1deg)}
.card:nth-child(3n+2){transform:rotate(1deg)}
.card:hover{transform:translate(-3px,-3px) rotate(0);box-shadow:8px 8px 0 var(--ink)}
.card .ic{width:62px;height:62px;border:2.5px solid var(--ink);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:14px}
.card.c1 .ic{background:var(--tomato)}.card.c2 .ic{background:var(--sky)}.card.c3 .ic{background:var(--mint)}
.card.c4 .ic{background:var(--sun)}.card.c5 .ic{background:var(--berry)}.card.c6 .ic{background:var(--mint)}
.card h3{margin:0 0 .25em}
.card p{color:var(--ink-soft);font-size:.95rem;margin:0 0 16px}
.card .go{font-family:var(--display);font-weight:700;color:var(--tomato)}
.tag{position:absolute;top:16px;right:16px;font-family:var(--display);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;padding:4px 9px;border:2px solid var(--ink);border-radius:8px;background:var(--mint);color:#fff}
.tag.soon{background:var(--paper);color:var(--ink-soft)}
.soonlbl{font-family:var(--display);font-weight:700;color:#b9ad9a}

/* what's new */
.updates{max-width:680px}
.u{display:flex;gap:18px;padding:16px 0;border-bottom:1px dashed var(--line)}
.u .date{font-family:var(--display);font-weight:700;color:var(--tomato);min-width:96px;font-size:.92rem;padding-top:2px}
.u h3{margin:0 0 .15em;font-size:1.05rem}
.u p{margin:0;color:var(--ink-soft);font-size:.95rem}

/* features */
.feature-band{background:var(--ink);color:var(--paper);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.feats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:30px}
.feat .fi{font-size:1.8rem;margin-bottom:6px}
.feat h3{color:var(--paper)}
.feat p{color:#c9c1b3;margin:0;font-size:.96rem}

/* maker strip */
.maker{display:grid;grid-template-columns:.8fr 1.2fr;gap:34px;align-items:center;background:var(--paper-2);border:2.5px solid var(--ink);border-radius:24px;padding:38px;box-shadow:var(--pop)}
.maker .pic{aspect-ratio:1;border:2.5px solid var(--ink);border-radius:18px;background:repeating-linear-gradient(45deg,var(--sun),var(--sun) 14px,var(--paper) 14px,var(--paper) 28px);display:flex;align-items:center;justify-content:center;font-size:4rem}
.maker p:last-child{margin:0}

/* newsletter */
.news{text-align:center}
.news .box{max-width:560px;margin:0 auto;background:var(--tomato);border:2.5px solid var(--ink);border-radius:24px;padding:40px 30px;box-shadow:var(--pop);color:#fff}
.news h2{color:#fff}
.news form{display:flex;gap:10px;max-width:420px;margin:18px auto 8px;flex-wrap:wrap}
.news input{flex:1;min-width:200px;padding:13px 16px;border:2.5px solid var(--ink);border-radius:12px;font-family:inherit;font-size:1rem}
.news small{color:#ffe6df}

/* prose pages */
.prose{background:var(--paper-2);max-width:760px;margin:46px auto;padding:42px 46px;border:2.5px solid var(--ink);border-radius:24px;box-shadow:var(--pop)}
.prose h1{font-size:2.3rem}.prose h2{font-size:1.3rem;margin-top:1.5em}
.prose .updated{color:var(--ink-soft);font-size:.92rem;margin-top:-.3em}
.prose ul{padding-left:20px}

/* game stage */
.game-stage{max-width:560px;margin:34px auto;text-align:center}
.scorebar{display:inline-flex;gap:0;margin:8px 0 22px;border:2.5px solid var(--ink);border-radius:14px;overflow:hidden;box-shadow:var(--pop-sm)}
.scorebar span{padding:10px 22px;font-weight:600;color:var(--ink-soft);background:var(--paper-2)}
.scorebar span+span{border-left:2.5px solid var(--ink)}
.scorebar b{display:block;font-family:var(--display);color:var(--ink);font-size:1.25rem}

/* footer */
.site-foot{background:var(--ink);color:#c9c1b3;border-top:2px solid var(--ink);padding:48px 0 30px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;margin-bottom:30px}
.site-foot .brand{color:var(--paper)}
.site-foot h4{font-family:var(--display);color:var(--paper);margin:0 0 12px;font-size:.95rem}
.site-foot a{display:block;color:#c9c1b3;padding:4px 0}
.site-foot a:hover{color:var(--sun)}
.foot-bottom{border-top:1px solid #44403a;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.88rem}
.socials{display:flex;gap:10px}
.socials a{width:34px;height:34px;border:2px solid #5a554d;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--paper)}
.socials a:hover{background:var(--sun);color:var(--ink);border-color:var(--sun)}

/* load animation */
.reveal{opacity:0;transform:translateY(16px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.reveal.d1{animation-delay:.08s}.reveal.d2{animation-delay:.18s}.reveal.d3{animation-delay:.3s}.reveal.d4{animation-delay:.42s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.reveal,.blob,.marquee div{animation:none;opacity:1;transform:none}}

@media(max-width:820px){
  .hero-grid{grid-template-columns:1fr}.hero-art{height:200px;order:-1}
  .maker{grid-template-columns:1fr}.foot-grid{grid-template-columns:1fr 1fr}
  .nav a:not(.play){display:none}
}
