/* Jules That Games — component styles. Tokens come from theme.json; this file
   styles the custom cosy components. Colours reference --wp--preset--color--*. */
:root{
  --jtg-pink:var(--wp--preset--color--primary);
  --jtg-pink-soft:var(--wp--preset--color--pink-soft);
  --jtg-pink2:#f3cdda;
  --jtg-green:var(--wp--preset--color--heading);
  --jtg-crimson:var(--wp--preset--color--crimson);
  --jtg-sage:var(--wp--preset--color--sage);
  --jtg-cream:var(--wp--preset--color--cream);
  --jtg-paper:var(--wp--preset--color--paper);
  --jtg-ink:var(--wp--preset--color--text);
  --jtg-body:var(--wp--preset--color--body);
  --d:var(--wp--preset--font-family--display);
  --s:var(--wp--preset--font-family--body);
  --jtg-shadow:0 24px 48px -28px rgba(31,42,29,.45);
  --jtg-shadow-sm:0 12px 28px -20px rgba(31,42,29,.4);
  --jtg-r:18px;
  --logo:url('../images/jules-logo.png');
}

/* ---------- Header ---------- */
.wp-block-template-part header.jtg-header,
.jtg-header{position:sticky;top:0;z-index:40;background:rgba(253,250,244,.86);backdrop-filter:blur(10px);border-bottom:1px solid rgba(31,42,29,.1)}
.jtg-mark{width:40px;height:40px;border-radius:50%;background:var(--jtg-pink);background-image:var(--logo);background-size:175%;background-position:50% 9%;background-repeat:no-repeat;border:2px solid #fff;box-shadow:var(--jtg-shadow-sm);flex:none}
.jtg-iconbtn{background:transparent;border:1px solid rgba(31,42,29,.18);width:42px;height:42px;border-radius:12px;display:grid;place-items:center;cursor:pointer;color:var(--jtg-green);transition:background .15s,border-color .15s}
.jtg-iconbtn:hover{background:var(--jtg-pink-soft);border-color:var(--jtg-pink)}
#jtgCosy.on{background:var(--jtg-pink);border-color:var(--jtg-pink);color:var(--jtg-green)}

/* core navigation tweaks */
.wp-block-navigation{font-family:var(--s);font-weight:600}

/* ---------- Masthead ---------- */
.jtg-hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--jtg-pink-soft),var(--jtg-paper));border-bottom:1px solid rgba(31,42,29,.08)}
.jtg-hero .jtg-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;max-width:1180px;margin:0 auto;padding:clamp(48px,7vw,84px) 28px clamp(40px,6vw,70px)}
.jtg-greet{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(63,81,56,.16);border-radius:999px;padding:.42rem 1rem;font-family:var(--s);font-size:.82rem;font-weight:700;color:var(--jtg-green);box-shadow:var(--jtg-shadow-sm)}
.jtg-eyebrow{display:block;margin-top:16px;font-family:var(--s);font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--jtg-sage)}
.jtg-hero h1{font-family:var(--d);font-weight:800;color:var(--jtg-green);font-size:clamp(2.8rem,6vw,4.6rem);line-height:1;margin:4px 0 0}
.jtg-hero .jtg-lede{font-family:var(--d);font-style:italic;color:var(--jtg-green);opacity:.85;font-size:clamp(1.1rem,1.7vw,1.35rem);margin:20px 0 26px;max-width:40ch}
.jtg-actions{display:flex;gap:12px;flex-wrap:wrap}
.jtg-btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--s);font-weight:700;font-size:.92rem;border:none;border-radius:999px;padding:.85rem 1.7rem;cursor:pointer;text-decoration:none;background:var(--jtg-crimson);color:#fff;box-shadow:var(--jtg-shadow-sm);transition:transform .2s,background .2s}
.jtg-btn:hover{transform:translateY(-2px);background:var(--jtg-green);color:#fff}
.jtg-btn.pink{background:var(--jtg-pink);color:var(--jtg-green)}
.jtg-btn.pink:hover{background:var(--jtg-crimson);color:#fff}
.jtg-figure{position:relative;display:flex;align-items:flex-end;justify-content:center;min-height:clamp(320px,40vw,460px)}
.jtg-blob{position:absolute;width:min(420px,92%);aspect-ratio:1;bottom:-6%;left:50%;transform:translateX(-50%);background:radial-gradient(circle,var(--jtg-pink) 0%,var(--jtg-pink2) 48%,transparent 70%);opacity:.55;filter:blur(8px);z-index:0}
.jtg-figimg{position:relative;z-index:1;width:min(320px,88%);height:clamp(320px,40vw,460px);background:var(--logo) no-repeat center bottom/contain;transform-origin:bottom center}
.jtg-steam{position:absolute;left:31%;bottom:28%;width:34px;height:48px;z-index:2}
.jtg-steam span{position:absolute;bottom:0;left:50%;width:7px;height:24px;border-radius:8px;background:linear-gradient(to top,rgba(255,255,255,0),rgba(255,255,255,.9));filter:blur(3px);opacity:0}
.jtg-petals{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;filter:saturate(.6)}
.jtg-petal{position:absolute;top:0;opacity:0;will-change:transform,opacity}

/* ---------- Now playing ---------- */
.jtg-nowplaying{display:flex;align-items:center;gap:22px;background:linear-gradient(120deg,var(--jtg-pink-soft),#fff);border:1px solid rgba(63,81,56,.12);border-radius:var(--jtg-r);padding:18px 24px;box-shadow:var(--jtg-shadow-sm);max-width:1180px;margin:0 auto}
.jtg-np-ava{width:64px;height:64px;border-radius:50%;background:var(--jtg-pink);background-image:var(--logo);background-size:160%;background-position:50% 8%;background-repeat:no-repeat;border:3px solid #fff;box-shadow:var(--jtg-shadow-sm);flex:none}
.jtg-np-text{flex:1}
.jtg-np-text .jtg-eyebrow{margin-top:0}
.jtg-np-text h3{font-family:var(--d);font-size:1.5rem;color:var(--jtg-green);margin:2px 0 4px}
.jtg-np-text p{font-family:var(--s);font-size:.92rem;color:var(--jtg-body);margin:0}

/* ---------- Stats strip ---------- */
.jtg-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center;max-width:1180px;margin:0 auto;padding:clamp(38px,4.5vw,60px) 28px}
.jtg-stat .num{display:block;font-family:var(--d);font-weight:800;font-size:clamp(2rem,4vw,2.8rem);color:var(--jtg-crimson);line-height:1}
.jtg-stat .lbl{display:block;font-family:var(--s);font-weight:600;font-size:.82rem;color:var(--jtg-green);margin-top:7px}

/* ---------- Cards (games + posts) ---------- */
.jtg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.jtg-card{cursor:pointer;background:#fff;border:1px solid rgba(31,42,29,.09);border-radius:var(--jtg-r);overflow:hidden;transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column;text-decoration:none}
.jtg-card:hover{transform:translateY(-6px);box-shadow:var(--jtg-shadow)}
.jtg-card .thumb{position:relative;overflow:hidden;aspect-ratio:3/4;background:var(--jtg-pink-soft)}
.jtg-card.post .thumb{aspect-ratio:4/3}
.jtg-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.jtg-card:hover .thumb img{transform:scale(1.06)}
.jtg-card .cat{position:absolute;top:12px;left:12px;font-family:var(--s);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,255,255,.92);color:var(--jtg-crimson);padding:4px 10px;border-radius:8px}
.jtg-card .body{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column}
.jtg-card .body h3{font-family:var(--d);font-size:1.42rem;color:var(--jtg-green);margin:0 0 8px}
.jtg-card .body p{font-family:var(--s);font-size:.94rem;color:var(--jtg-body);margin:0 0 16px}
.jtg-card .meta{margin-top:auto;display:flex;align-items:center;gap:10px;font-family:var(--s);font-size:.78rem;color:var(--jtg-sage);font-weight:600}
.jtg-card .meta .dot{width:3px;height:3px;border-radius:50%;background:currentColor}
.jtg-stars{color:var(--jtg-crimson);letter-spacing:1px;font-size:.85rem}

/* ---------- Cosiness meter ---------- */
.jtg-cosy-meter{display:inline-flex;align-items:center;gap:3px;margin:0 0 12px}
.jtg-cosy-meter svg{width:16px;height:16px}
.jtg-cosy-meter .on{color:var(--jtg-crimson)}
.jtg-cosy-meter .off{color:rgba(63,81,56,.2)}

/* ---------- Single game ---------- */
.jtg-game-top{display:grid;grid-template-columns:300px 1fr;gap:clamp(28px,4vw,52px);align-items:start;max-width:1180px;margin:0 auto;padding:24px 28px clamp(36px,5vw,56px)}
.jtg-game-cover{border-radius:var(--jtg-r);overflow:hidden;box-shadow:var(--jtg-shadow);border:8px solid #fff;aspect-ratio:3/4}
.jtg-game-cover img{width:100%;height:100%;object-fit:cover;display:block}
.jtg-platforms{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}
.jtg-pf{font-family:var(--s);font-size:.8rem;font-weight:700;background:#fff;color:var(--jtg-green);border:1px solid rgba(31,42,29,.16);padding:.38rem .9rem;border-radius:999px}

/* ---------- Back to top ---------- */
.jtg-totop{position:fixed;left:18px;bottom:18px;z-index:60;width:48px;height:48px;border-radius:50%;background:var(--jtg-pink);color:var(--jtg-green);border:2px solid #fff;box-shadow:var(--jtg-shadow);display:grid;place-items:center;cursor:pointer;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s,transform .3s,background .2s}
.jtg-totop.show{opacity:1;transform:none;pointer-events:auto}
.jtg-totop:hover{background:var(--jtg-crimson);color:#fff}

/* ---------- Cosy mode ---------- */
body.jtg-cosy{--wp--preset--color--paper:#f4e7d4;--wp--preset--color--white:#fbf1e4}
body.jtg-cosy .jtg-header{background:rgba(244,231,212,.9)}
.jtg-warmth{position:fixed;inset:0;pointer-events:none;z-index:46;background:radial-gradient(120% 82% at 50% 16%,rgba(255,210,140,0) 46%,rgba(150,86,24,.17) 100%);opacity:0;transition:opacity .45s}
body.jtg-cosy .jtg-warmth{opacity:1}

/* ---------- Scroll reveal (progressive enhancement) ---------- */
html.js .jtg-reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
html.js .jtg-reveal.in{opacity:1;transform:none}

/* ---------- Animations ---------- */
@media(prefers-reduced-motion:no-preference){
  .jtg-figimg{animation:jtg-floaty 6s ease-in-out infinite}
  .jtg-steam span{animation:jtg-steam 3.4s ease-in-out infinite}
  .jtg-steam span:nth-child(2){left:28%;animation-delay:1.1s}
  .jtg-steam span:nth-child(3){left:68%;animation-delay:2.1s}
}
@keyframes jtg-floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes jtg-steam{0%{opacity:0;transform:translateY(0) scaleX(1)}25%{opacity:.85}100%{opacity:0;transform:translateY(-34px) scaleX(1.7)}}
@keyframes jtg-petalfall{0%{opacity:0;transform:translateY(-40px) translateX(0) rotate(0)}12%{opacity:.3}88%{opacity:.3}100%{opacity:0;transform:translateY(var(--fall,520px)) translateX(var(--drift,30px)) rotate(330deg)}}
@media(prefers-reduced-motion:reduce){html.js .jtg-reveal{opacity:1;transform:none;transition:none}.jtg-petals{display:none}}

/* ---------- Footer links: pink, no underline, no colour shift ---------- */
footer.wp-block-group a:where(:not(.wp-social-link-anchor)){color:var(--jtg-pink);text-decoration:none}
footer.wp-block-group a:where(:not(.wp-social-link-anchor)):hover,
footer.wp-block-group a:where(:not(.wp-social-link-anchor)):focus{color:var(--jtg-pink);text-decoration:none;opacity:.78}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .jtg-hero .jtg-inner{grid-template-columns:1fr}
  .jtg-figure{min-height:auto}
  .jtg-figimg{height:clamp(260px,54vw,340px)}
  .jtg-stats{grid-template-columns:1fr 1fr;gap:28px 16px}
  .jtg-grid{grid-template-columns:1fr 1fr}
  .jtg-game-top{grid-template-columns:1fr}
  .jtg-game-cover{max-width:280px}
}
@media(max-width:560px){
  .jtg-grid{grid-template-columns:1fr}
  .jtg-nowplaying{flex-wrap:wrap}
}
