/* ============================================================
   PlayRanko — leaderboard / weekly chart of free mobile games
   Palette: warm-neutral light. Blue = energy, Yellow = ratings only.
   ============================================================ */

:root{
  --bg:#F5F4F0;
  --panel:#FFFFFF;
  --text:#17171A;
  --muted:#6E6E76;
  --accent:#2540E8;
  --accent-ink:#1B31B8;
  --accent-wash:#EEF0FD;
  --signal:#FFC400;
  --border:#E4E2DB;
  --border-2:#D9D7CE;

  --font-display:'Anton', Impact, system-ui, sans-serif;
  --font-head:'Archivo', system-ui, sans-serif;
  --font-body:system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;
  --container:1180px;
  --gutter:clamp(18px, 5vw, 40px);
  --shadow-sm:0 1px 2px rgba(23,23,26,.05), 0 4px 14px rgba(23,23,26,.05);
  --shadow-md:0 2px 6px rgba(23,23,26,.06), 0 18px 44px rgba(23,23,26,.10);
  --ring:0 0 0 3px rgba(37,64,232,.35);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3{ margin:0; font-family:var(--font-head); line-height:1.08; letter-spacing:-.02em; }
p{ margin:0; }
ul,ol{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
.svg-defs{ position:absolute; width:0; height:0; overflow:hidden; }

:focus-visible{ outline:none; box-shadow:var(--ring); border-radius:6px; }

.skip-link{
  position:absolute; left:12px; top:-60px; z-index:100;
  background:var(--text); color:#fff; padding:10px 16px; border-radius:8px;
  transition:top .18s ease;
}
.skip-link:focus{ top:12px; text-decoration:none; }

/* ---------- layout ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.container--narrow{ max-width:800px; }

.section{ padding-block:clamp(56px, 8vw, 104px); }
.section--alt{ background:var(--panel); border-block:1px solid var(--border); }

.section__head{ max-width:660px; margin-bottom:clamp(28px,4vw,48px); }
.section__title{
  font-size:clamp(30px, 4.4vw, 48px);
  font-weight:800;
}
.section__lead{ margin-top:14px; color:var(--muted); font-size:1.06rem; }

.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-head); font-weight:700;
  text-transform:uppercase; letter-spacing:.14em; font-size:.74rem;
  color:var(--accent); margin:0 0 16px;
}
.eyebrow__dot{ width:8px; height:8px; border-radius:2px; background:var(--signal); transform:rotate(45deg); }
.eyebrow--light{ color:#fff; }
.eyebrow--light .eyebrow__dot{ background:var(--signal); }

.hl{ color:var(--accent); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-head); font-weight:700; font-size:.98rem;
  padding:13px 22px; border-radius:var(--radius-pill);
  border:2px solid transparent; transition:transform .12s ease, background .15s ease, box-shadow .15s ease, color .15s ease;
  text-align:center; white-space:nowrap;
}
.btn:hover{ text-decoration:none; }
.btn:active{ transform:translateY(1px); }
.btn__ico{ flex:none; }
.btn--primary{ background:var(--accent); color:#fff; }
.btn--primary:hover{ background:var(--accent-ink); box-shadow:0 8px 20px rgba(37,64,232,.28); }
.btn--signal{ background:var(--signal); color:#17171A; }
.btn--signal:hover{ background:#F0B800; box-shadow:0 8px 20px rgba(255,196,0,.32); }
.btn--ghost{ background:transparent; color:var(--text); border-color:var(--border-2); }
.btn--ghost:hover{ background:var(--bg); border-color:var(--text); }
.btn--outline{ background:transparent; color:var(--accent); border-color:var(--accent); padding:10px 18px; font-size:.92rem; }
.btn--outline:hover{ background:var(--accent); color:#fff; }
.btn--block{ width:100%; }
.btn--sm{ padding:9px 16px; font-size:.9rem; }

/* ---------- header ---------- */
.header{
  position:sticky; top:0; z-index:60;
  background:rgba(245,244,240,.86);
  backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--border);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; min-height:66px;
}
.logo{
  font-family:var(--font-display);
  font-size:1.6rem; letter-spacing:.03em; text-transform:uppercase;
  color:var(--text); line-height:1;
}
.logo:hover{ text-decoration:none; }
.logo__accent{ color:var(--accent); }

.nav__list{ display:flex; align-items:center; gap:4px; }
.nav__link{
  display:inline-block; color:var(--text); font-weight:600; font-size:.95rem;
  padding:9px 13px; border-radius:9px;
}
.nav__link:hover{ background:var(--panel); text-decoration:none; color:var(--accent); }
.nav__item--cta{ margin-left:6px; }
.nav__link--cta{ background:var(--accent); color:#fff; padding:9px 18px; }
.nav__link--cta:hover{ background:var(--accent-ink); color:#fff; }

.burger{
  display:none; width:44px; height:44px; border:1px solid var(--border-2);
  background:var(--panel); border-radius:11px; position:relative;
}
.burger__bar{
  position:absolute; left:11px; right:11px; height:2px; background:var(--text);
  border-radius:2px; transition:transform .2s ease, opacity .2s ease;
}
.burger__bar:nth-child(1){ top:15px; }
.burger__bar:nth-child(2){ top:21px; }
.burger__bar:nth-child(3){ top:27px; }
.burger.is-open .burger__bar:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.burger.is-open .burger__bar:nth-child(2){ opacity:0; }
.burger.is-open .burger__bar:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* ---------- hero ---------- */
.hero{ padding-block:clamp(40px,6vw,76px); position:relative; }
.hero__grid{
  display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(28px,4vw,56px);
  align-items:center;
}
.hero__title{
  font-size:clamp(40px, 6.4vw, 76px);
  font-weight:800; letter-spacing:-.03em; margin-bottom:20px;
}
.hero__lead{ font-size:1.14rem; color:var(--muted); max-width:33ch; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:28px; }

.hero__stats{
  display:flex; gap:clamp(18px,4vw,40px); margin-top:38px;
  padding-top:26px; border-top:1px solid var(--border);
}
.hero__stat{ display:flex; flex-direction:column; }
.hero__statnum{ font-family:var(--font-display); font-size:2rem; line-height:1; letter-spacing:.01em; }
.hero__statlab{ font-size:.82rem; color:var(--muted); margin-top:6px; max-width:12ch; }

/* week card */
.weekcard{
  background:var(--panel); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:clamp(22px,3vw,30px);
  box-shadow:var(--shadow-md); position:relative;
}
.weekcard::before{
  content:""; position:absolute; inset:0; border-radius:inherit;
  padding:1px; background:linear-gradient(160deg, rgba(37,64,232,.35), transparent 42%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none;
}
.weekcard__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.weekcard__label{
  font-family:var(--font-head); font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; font-size:.72rem; color:var(--muted);
}
.rankpill{
  font-family:var(--font-display); font-size:1.1rem; letter-spacing:.04em;
  color:#fff; background:var(--accent); padding:5px 13px; border-radius:var(--radius-pill);
}
.weekcard__head{ display:flex; align-items:center; gap:16px; }
.weekcard__icon{ width:88px; height:88px; border-radius:20px; border:1px solid var(--border); flex:none; }
.weekcard__name{ font-family:var(--font-head); font-size:1.5rem; font-weight:800; }
.weekcard__dev{ color:var(--muted); font-size:.92rem; margin-top:3px; }

.weekcard__ratingrow{
  display:flex; align-items:center; gap:18px; margin:22px 0;
  padding:16px 0; border-block:1px solid var(--border);
}
.bignum{
  font-family:var(--font-display); font-size:clamp(64px, 9vw, 88px);
  line-height:.82; color:var(--text); letter-spacing:.01em;
}
.weekcard__ratingmeta{ display:flex; flex-direction:column; gap:7px; }
.weekcard__ratingtxt{ font-size:.82rem; color:var(--muted); }
.weekcard__desc{ color:var(--muted); font-size:.98rem; margin-bottom:22px; }

/* ---------- stars ---------- */
.stars{ display:inline-block; line-height:0; }
.stars svg{ display:block; }
.stars--sm svg{ width:104px; height:auto; }

/* ---------- classifica / rank list ---------- */
.ranklist{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:20px;
  counter-reset:none;
}
.rankcard{
  display:grid; grid-template-columns:auto 72px 1fr; gap:18px; align-items:start;
  background:var(--panel); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:24px; transition:transform .14s ease, box-shadow .16s ease, border-color .16s ease;
}
.rankcard:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--border-2); }
.rankcard__rank{
  font-family:var(--font-display); font-size:clamp(52px, 6vw, 74px); line-height:.8;
  color:#C7C5BB; letter-spacing:.01em; margin-top:-2px;
}
.rankcard--top .rankcard__rank{ color:var(--accent); }
.rankcard__icon{ width:72px; height:72px; border-radius:17px; border:1px solid var(--border); }
.rankcard__body{ min-width:0; }
.rankcard__topline{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.rankcard__name{ font-family:var(--font-head); font-size:1.24rem; font-weight:800; }
.ratingbadge{
  flex:none; font-family:var(--font-display); font-size:1rem; letter-spacing:.03em;
  color:#5A4600; background:var(--signal); padding:3px 11px; border-radius:var(--radius-pill);
}
.rankcard__meta{ color:var(--muted); font-size:.86rem; margin:4px 0 10px; }
.rankcard__desc{ color:var(--muted); font-size:.95rem; margin:12px 0 16px; }

.ranklist__note{
  margin-top:26px; color:var(--muted); font-size:.86rem; text-align:center;
}

/* ---------- split sections ---------- */
.split{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,56px);
  align-items:center;
}
.split--reverse .split__media{ order:0; }
.paylist{ display:grid; gap:16px; margin:24px 0 28px; }
.paylist__item{ display:flex; gap:14px; align-items:flex-start; font-size:1rem; color:var(--muted); }
.paylist__item strong{ color:var(--text); }
.paylist__mark{
  flex:none; width:28px; height:28px; border-radius:9px; color:#fff; background:var(--accent);
  display:grid; place-items:center; margin-top:1px;
}
.split__media img{
  width:100%; height:auto; border-radius:var(--radius-lg);
  border:1px solid var(--border); box-shadow:var(--shadow-sm); object-fit:cover;
}
.split__cap{ margin-top:12px; font-size:.84rem; color:var(--muted); text-align:center; }

/* ---------- trust ---------- */
.trust{ display:grid; gap:14px; }
.trust__item{
  display:flex; gap:16px; align-items:flex-start;
  background:var(--panel); border:1px solid var(--border); border-radius:var(--radius);
  padding:18px 20px;
}
.section .split .trust__item{ box-shadow:var(--shadow-sm); }
.trust__ico{
  flex:none; width:44px; height:44px; border-radius:12px;
  background:var(--accent-wash); color:var(--accent); display:grid; place-items:center;
}
.trust__title{ font-family:var(--font-head); font-size:1.06rem; font-weight:700; }
.trust__text{ color:var(--muted); font-size:.92rem; margin-top:5px; }

/* ---------- reviews ---------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review{
  margin:0; background:var(--panel); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:26px; display:flex; flex-direction:column; gap:14px;
}
.review__quote{ margin:0; font-size:1.02rem; color:var(--text); }
.review__author{ display:flex; align-items:center; gap:13px; margin-top:auto; }
.review__avatar{
  flex:none; width:44px; height:44px; border-radius:50%;
  background:var(--accent); color:#fff; display:grid; place-items:center;
  font-family:var(--font-head); font-weight:700; font-size:.92rem; letter-spacing:.02em;
}
.review__who{ display:flex; flex-direction:column; line-height:1.3; }
.review__role{ color:var(--muted); font-size:.84rem; }

/* ---------- subscribe ---------- */
.subscribe{
  position:relative; color:#fff; padding-block:clamp(56px,8vw,96px);
  background:linear-gradient(135deg, rgba(15,20,54,.92), rgba(27,49,184,.86)), url("assets/img/bg/hero-bg.webp") center/cover no-repeat;
}
.subscribe__inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); align-items:center; }
.subscribe__title{ font-size:clamp(28px,4vw,44px); font-weight:800; color:#fff; }
.subscribe__lead{ margin-top:14px; color:rgba(255,255,255,.82); font-size:1.06rem; max-width:40ch; }

.subform{
  background:var(--panel); color:var(--text); border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,30px); box-shadow:var(--shadow-md); display:grid; gap:15px;
}
.subform__row{ display:grid; grid-template-columns:1fr 1fr; gap:15px; }
.subform__field{ display:flex; flex-direction:column; gap:7px; }
.subform__label{ font-size:.82rem; font-weight:600; color:var(--text); }
.subform__opt{ color:var(--muted); font-weight:400; }
.subform__req{ color:var(--accent); }
.subform__input{
  font-family:inherit; font-size:.98rem; padding:12px 14px;
  border:1px solid var(--border-2); border-radius:11px; background:#fff; color:var(--text);
}
.subform__input::placeholder{ color:#A9A7A0; }
.subform__input:focus-visible{ border-color:var(--accent); box-shadow:var(--ring); outline:none; }
.subform__consent{ display:flex; gap:11px; align-items:flex-start; font-size:.86rem; color:var(--muted); }
.subform__consent input{ margin-top:3px; width:18px; height:18px; accent-color:var(--accent); flex:none; }
.subform__success{
  background:var(--accent-wash); border:1px solid #C6CEFB; color:var(--accent-ink);
  border-radius:11px; padding:14px 16px; font-size:.92rem; font-weight:500;
}

/* ---------- faq ---------- */
.faq{ display:grid; gap:12px; }
.faq__item{
  background:var(--panel); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden;
}
.faq__item--open{ border-color:var(--border-2); }
.faq__q{ margin:0; }
.faq__btn{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px;
  background:transparent; border:0; padding:19px 22px; text-align:left;
  font-family:var(--font-head); font-weight:700; font-size:1.04rem; color:var(--text);
}
.faq__chev{ flex:none; color:var(--accent); transition:transform .22s ease; }
.faq__item--open .faq__chev{ transform:rotate(180deg); }
.faq__a{
  max-height:0; overflow:hidden; transition:max-height .28s ease;
}
.faq__a p{ padding:0 22px 20px; color:var(--muted); }
@media (prefers-reduced-motion: reduce){ .faq__a{ transition:none; } }

/* ---------- footer ---------- */
.footer{ background:var(--text); color:#D8D8DD; }
.footer__grid{
  display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:32px;
  padding-block:clamp(44px,6vw,68px);
}
.logo--footer{ color:#fff; font-size:1.5rem; }
.footer__tag{ margin-top:14px; color:#9A9AA3; font-size:.92rem; max-width:34ch; }
.footer__h{ font-family:var(--font-head); font-size:.8rem; text-transform:uppercase; letter-spacing:.14em; color:#fff; margin-bottom:14px; }
.footer__list{ display:grid; gap:9px; }
.footer__list a{ color:#B7B7BF; font-size:.94rem; }
.footer__list a:hover{ color:#fff; }
.footer__contact a{ color:#fff; font-size:.98rem; }
.footer__bottom{ border-top:1px solid #2C2C31; }
.footer__bottominner{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; padding-block:20px; }
.footer__bottom p{ color:#8A8A92; font-size:.82rem; }
.footer__disc{ max-width:52ch; }

/* ---------- back to top ---------- */
.totop{
  position:fixed; right:20px; bottom:20px; z-index:50;
  width:48px; height:48px; border-radius:50%; border:1px solid var(--border-2);
  background:var(--panel); color:var(--accent); display:grid; place-items:center;
  box-shadow:var(--shadow-md); transition:transform .14s ease, opacity .2s ease;
}
.totop:hover{ transform:translateY(-3px); }
.totop[hidden]{ display:none; }

/* ---------- cookie banner ---------- */
.cookie{
  position:fixed; left:0; right:0; bottom:0; z-index:70;
  background:var(--panel); border-top:1px solid var(--border); box-shadow:0 -10px 30px rgba(23,23,26,.08);
}
.cookie[hidden]{ display:none; }
.cookie__inner{ display:flex; align-items:center; gap:20px; padding-block:16px; flex-wrap:wrap; }
.cookie__text{ flex:1 1 320px; font-size:.9rem; color:var(--muted); }
.cookie__actions{ display:flex; gap:10px; flex:none; }

/* ---------- legal pages ---------- */
.legal{ padding-block:clamp(40px,6vw,72px); }
.legal__head{ margin-bottom:32px; }
.legal__updated{ color:var(--muted); font-size:.9rem; margin-top:12px; }
.legal__back{ display:inline-flex; align-items:center; gap:7px; margin-bottom:22px; font-weight:600; }
.legal h1{ font-family:var(--font-head); font-size:clamp(30px,4.4vw,46px); font-weight:800; }
.legal__body h2{ font-family:var(--font-head); font-size:1.28rem; font-weight:700; margin:34px 0 10px; }
.legal__body h3{ font-family:var(--font-head); font-size:1.06rem; font-weight:700; margin:22px 0 8px; }
.legal__body p, .legal__body li{ color:#3C3C42; }
.legal__body p{ margin-bottom:12px; }
.legal__body ul{ list-style:disc; padding-left:22px; margin-bottom:14px; display:grid; gap:7px; }
.legal__body a{ color:var(--accent); }
.legal__card{ background:var(--panel); border:1px solid var(--border); border-radius:var(--radius); padding:22px 24px; margin-bottom:20px; }

/* ---------- responsive ---------- */
@media (max-width: 1000px){
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .footer__brand{ grid-column:1 / -1; }
}
@media (max-width: 900px){
  .nav{
    position:fixed; inset:66px 0 auto 0; background:var(--panel);
    border-bottom:1px solid var(--border); box-shadow:var(--shadow-md);
    transform:translateY(-140%); transition:transform .26s ease; visibility:hidden;
  }
  .nav.is-open{ transform:translateY(0); visibility:visible; }
  @media (prefers-reduced-motion: reduce){ .nav{ transition:none; } }
  .nav__list{ flex-direction:column; align-items:stretch; gap:2px; padding:14px var(--gutter) 20px; }
  .nav__link{ padding:13px 12px; font-size:1.02rem; border-radius:11px; }
  .nav__item--cta{ margin-left:0; margin-top:6px; }
  .nav__link--cta{ text-align:center; }
  .burger{ display:block; }
  .hero__grid{ grid-template-columns:1fr; }
  .hero__lead{ max-width:none; }
  .ranklist{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; }
  .split--reverse .split__media{ order:-1; }
  .reviews{ grid-template-columns:1fr; }
  .subscribe__inner{ grid-template-columns:1fr; }
}
@media (max-width: 560px){
  body{ font-size:16px; }
  .hero__stats{ flex-wrap:wrap; gap:18px 26px; }
  .rankcard{ grid-template-columns:auto 1fr; gap:14px 16px; padding:20px; }
  .rankcard__icon{ grid-row:1; grid-column:2; width:58px; height:58px; }
  .rankcard__rank{ grid-row:1 / span 2; font-size:46px; }
  .rankcard__body{ grid-column:1 / -1; }
  .subform__row{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .footer__bottominner{ flex-direction:column; }
  .weekcard__ratingrow{ gap:14px; }
  .bignum{ font-size:60px; }
}
