/* hps theme */
:root{--hps-bg:#eef3f6;--hps-panel:#ffffff;--hps-ink:#152238;--hps-mut:#5d6b80;--hps-acc:#12a09c;--hps-acc2:#c4233d;--hps-line:#d5dee6}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--hps-bg);color:var(--hps-ink);font-family:'Archivo',sans-serif;line-height:1.6}
h1,h2,h3{font-family:'Archivo Black',sans-serif;line-height:1.2}
a{color:var(--hps-acc)}
img{max-width:100%}
.hps-wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.hps-topbar{background:var(--hps-panel);border-bottom:1px solid var(--hps-line);font-size:.8rem;padding:6px 0}
.hps-topbar .hps-wrap{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:var(--hps-mut)}
.hps-topbar b{color:var(--hps-acc)}
.hps-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:14px;flex-wrap:wrap}
.hps-logo{font-family:'Archivo Black',sans-serif;font-size:1.3rem;color:var(--hps-ink);text-decoration:none}
.hps-logo span{color:var(--hps-acc)}
.hps-menu{display:flex;gap:22px;flex-wrap:wrap}
.hps-menu a{color:var(--hps-mut);text-decoration:none;font-weight:600;font-size:.95rem}
.hps-menu a:hover{color:var(--hps-ink)}
.hps-btn{display:inline-block;vertical-align:middle;padding:12px 26px;border-radius:8px;font-weight:700;text-decoration:none;border:2px solid transparent;cursor:pointer;font-size:1rem;font-family:'Archivo',sans-serif}
.hps-btn-solid{background:var(--hps-acc);color:var(--hps-bg)}
.hps-btn-solid:hover{filter:brightness(1.1)}
.hps-btn-ghost{border-color:var(--hps-acc);color:var(--hps-acc);background:transparent}
.hps-btn-ghost:hover{background:var(--hps-panel)}
.hps-hero{padding:70px 0 50px;text-align:center}
.hps-hero-grid{display:grid;gap:40px;}
.hps-hero h1{font-size:2.6rem;margin-bottom:18px}
.hps-hero p{color:var(--hps-mut);font-size:1.1rem;max-width:640px;margin:0 auto 26px}
.hps-badge{display:inline-block;background:var(--hps-panel);border:1px solid var(--hps-line);color:var(--hps-acc);border-radius:999px;padding:5px 14px;font-size:.8rem;font-weight:700;margin-bottom:18px}
.hps-hero-card{background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;padding:26px;text-align:center}
.hps-hero-card .hps-big{font-size:3.4rem}
.hps-sec{padding:52px 0}
.hps-sec-alt{background:var(--hps-panel)}
.hps-sec h2{font-size:1.9rem;margin-bottom:8px}
.hps-sec-sub{color:var(--hps-mut);margin-bottom:30px;max-width:620px}
.hps-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.hps-card{background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;padding:22px}
.hps-sec-alt .hps-card{background:var(--hps-bg)}
.hps-card h3{margin-bottom:8px;font-size:1.1rem}
.hps-card p{color:var(--hps-mut);font-size:.95rem}
.hps-step-n{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:50%;background:var(--hps-acc);color:var(--hps-bg);font-weight:800;margin-bottom:12px}
.hps-games{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.hps-game-card{background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;padding:26px;display:flex;flex-direction:column;gap:12px}
.hps-game-emoji{font-size:2.6rem}
.hps-game-card h3{font-size:1.25rem}
.hps-game-card p{color:var(--hps-mut);flex:1}
.hps-faq-item{border:1px solid var(--hps-line);border-radius:8px;margin-bottom:12px;background:var(--hps-panel);overflow:hidden}
.hps-faq-q{width:100%;text-align:left;background:none;border:none;color:var(--hps-ink);font-weight:700;font-size:1rem;padding:16px 20px;cursor:pointer;display:flex;justify-content:space-between;gap:10px;font-family:'Archivo',sans-serif}
.hps-faq-a{display:none;padding:0 20px 16px;color:var(--hps-mut)}
.hps-faq-item.hps-open .hps-faq-a{display:block}
.hps-strip{border:1px dashed var(--hps-acc);border-radius:8px;padding:18px 22px;color:var(--hps-mut);font-size:.92rem;margin:10px 0 30px}
.hps-strip b{color:var(--hps-acc)}
.hps-legal{max-width:820px;margin:0 auto;padding:50px 0}
.hps-legal h1{font-size:2.1rem;margin-bottom:6px}
.hps-legal h2{font-size:1.25rem;margin:28px 0 10px}
.hps-legal p,.hps-legal li{color:var(--hps-mut)}
.hps-legal ul{padding-left:22px;margin:10px 0}
.hps-legal-date{font-size:.85rem;color:var(--hps-mut);margin-bottom:10px}
.hps-legal-table{width:100%;border-collapse:collapse;margin:14px 0;font-size:.9rem}
.hps-legal-table th,.hps-legal-table td{border:1px solid var(--hps-line);padding:9px 12px;text-align:left;color:var(--hps-mut)}
.hps-legal-table th{color:var(--hps-ink)}
.hps-orglist li{margin-bottom:12px}
.hps-crumb{padding:18px 0;font-size:.88rem;color:var(--hps-mut)}
.hps-crumb a{color:var(--hps-mut)}
.hps-form{display:grid;gap:14px;max-width:560px}
.hps-form label{font-weight:600;font-size:.92rem}
.hps-form input,.hps-form textarea,.hps-form select{width:100%;padding:11px 14px;border-radius:4px;border:1px solid var(--hps-line);background:var(--hps-bg);color:var(--hps-ink);font-family:'Archivo',sans-serif;margin-top:5px}
.hps-note{font-size:.85rem;color:var(--hps-mut)}
.hps-footer{background:var(--hps-panel);border-top:1px solid var(--hps-line);padding:44px 0 26px;margin-top:50px}
.hps-footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:26px;margin-bottom:24px}
.hps-footer h4{margin-bottom:12px;font-size:1rem}
.hps-footer a{display:block;color:var(--hps-mut);text-decoration:none;margin-bottom:8px;font-size:.92rem}
.hps-footer a:hover{color:var(--hps-ink)}
.hps-footer-note{color:var(--hps-mut);font-size:.85rem;border-top:1px solid var(--hps-line);padding-top:18px}
.hps-footer-note b{color:var(--hps-acc)}
.hps-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);display:none;align-items:center;justify-content:center;z-index:90;padding:20px}
.hps-overlay.hps-show{display:flex}
.hps-modal{background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;max-width:440px;width:100%;padding:30px;text-align:center}
.hps-modal h2{margin-bottom:12px}
.hps-modal p{color:var(--hps-mut);margin-bottom:20px}
.hps-modal .hps-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hps-cookiebar{position:fixed;left:16px;right:16px;bottom:16px;background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;padding:16px 20px;display:none;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;z-index:80}
.hps-cookiebar.hps-show{display:flex}
.hps-cookiebar p{color:var(--hps-mut);font-size:.9rem;margin:0}
@media(max-width:760px){.hps-hero h1{font-size:1.9rem}.hps-hero-grid{grid-template-columns:1fr}.hps-menu{gap:14px}}

/* --- polish layer --- */
.hps-nav{position:sticky;top:0;z-index:40;background:color-mix(in srgb, var(--hps-bg) 88%, transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
@supports not (backdrop-filter:blur(2px)){.hps-nav{background:var(--hps-bg)}}
.hps-hero{position:relative;overflow:hidden}
.hps-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(58% 78% at 84% 8%, #12a09c 0%, transparent 56%),radial-gradient(48% 66% at 8% 96%, #c4233d 0%, transparent 58%);
  opacity:.10}
.hps-hero .hps-wrap{position:relative;z-index:1}
.hps-hero h1{font-size:clamp(2rem,5vw,3rem);letter-spacing:-0.02em}
.hps-sec h2{position:relative;display:inline-block;padding-bottom:10px;letter-spacing:-0.01em}
.hps-sec h2::after{content:"";position:absolute;left:0;bottom:0;width:44px;height:3px;border-radius:3px;background:var(--hps-acc)}
.hps-card{transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.hps-card:hover{transform:translateY(-4px);border-color:var(--hps-acc);box-shadow:0 14px 34px rgba(0,0,0,.14)}
.hps-game-card{transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.hps-game-card:hover{transform:translateY(-4px);border-color:var(--hps-acc);box-shadow:0 16px 40px rgba(0,0,0,.18)}
.hps-btn-solid{box-shadow:0 8px 20px color-mix(in srgb, var(--hps-acc) 35%, transparent)}
.hps-btn-solid:active{transform:translateY(1px)}
.hps-btn:focus-visible{outline:3px solid var(--hps-acc2);outline-offset:2px}
.hps-hero-card{box-shadow:0 20px 60px rgba(0,0,0,.16)}

/* --- responsible trust band --- */
.hps-rg{position:relative;background:#0d1116;color:#e6edf5;padding:58px 0}
.hps-rg::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--hps-acc),var(--hps-acc2))}
.hps-rg-inner{max-width:840px;margin:0 auto;padding:0 20px;text-align:center}
.hps-rg h2{color:#fff;font-size:clamp(1.5rem,3vw,2rem);margin-bottom:14px}
.hps-rg p{color:#aeb9c6;font-size:1.02rem;line-height:1.7;margin:0 auto 30px;max-width:680px}
.hps-rg-logos{display:flex;flex-wrap:wrap;gap:34px 40px;align-items:center;justify-content:center;color:#e9eff6}
.hps-rg-logo{display:inline-flex;align-items:center;opacity:.8;transition:opacity .2s ease,transform .2s ease}
.hps-rg-logo:hover{opacity:1;transform:translateY(-2px)}
.hps-rg-logo svg{height:32px;width:auto;display:block}
.hps-rg-note{margin-top:28px;font-size:.85rem;color:#8b97a6}
.hps-rg-note a{color:#cdd8e4;text-decoration:underline;text-underline-offset:3px}
@media(max-width:620px){.hps-rg-logos{gap:26px}.hps-rg-logo svg{height:26px}}

/* --- account controls --- */
.hps-acct{display:flex;align-items:center;gap:10px}
.hps-acct-btn{padding:8px 16px;font-size:.88rem}
.hps-acct-me{display:flex;align-items:center;gap:10px}
.hps-acct-hi{font-size:.92rem;color:var(--hps-ink)}
.hps-acct-out{background:none;border:1px solid var(--hps-line);color:var(--hps-mut);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:.84rem}
.hps-acct-out:hover{color:var(--hps-ink);border-color:var(--hps-acc)}
.hps-check{display:flex;gap:9px;align-items:flex-start;font-size:.9rem;color:var(--hps-mut);margin-top:6px}
.hps-check input{margin-top:3px;width:auto}
.hps-form-err{color:#e5484d;font-size:.85rem;min-height:1.1em;margin:2px 0}

/* --- leaderboard --- */
.hps-lb{max-width:640px}
.hps-lb-table{width:100%;border-collapse:collapse;background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;overflow:hidden}
.hps-lb-table th,.hps-lb-table td{padding:12px 16px;text-align:left}
.hps-lb-table thead th{font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--hps-mut);border-bottom:1px solid var(--hps-line)}
.hps-lb-table th:last-child,.hps-lb-pts{text-align:right}
.hps-lb-table tbody tr{border-bottom:1px solid var(--hps-line)}
.hps-lb-table tbody tr:last-child{border-bottom:none}
.hps-lb-rank{width:52px;font-weight:800;color:var(--hps-acc)}
.hps-lb-name{font-weight:600;color:var(--hps-ink)}
.hps-lb-pts{font-variant-numeric:tabular-nums;color:var(--hps-ink)}
.hps-lb-you{background:color-mix(in srgb, var(--hps-acc) 14%, transparent)}
.hps-lb-you .hps-lb-name{color:var(--hps-acc)}
.hps-lb-note{margin-top:14px;font-size:.82rem;color:var(--hps-mut);max-width:640px}

/* --- level chip in nav --- */
.hps-lvl{display:inline-flex;align-items:center;gap:8px;text-decoration:none;padding:5px 10px;border:1px solid var(--hps-line);border-radius:999px;background:var(--hps-panel)}
.hps-lvl-badge{font-size:.8rem;color:var(--hps-mut)}
.hps-lvl-badge b{color:var(--hps-acc)}
.hps-lvl-bar{width:52px;height:6px;border-radius:6px;background:var(--hps-line);overflow:hidden}
.hps-lvl-bar i{display:block;height:100%;width:0;background:var(--hps-acc);transition:width .4s ease}

/* --- progress + badges --- */
.hps-prog-card{display:flex;flex-wrap:wrap;align-items:center;gap:18px;background:var(--hps-bg);border:1px solid var(--hps-line);border-radius:8px;padding:20px 24px;margin-bottom:22px}
.hps-prog-lv{font-size:2.2rem;font-weight:800;color:var(--hps-acc);line-height:1;min-width:70px}
.hps-prog-lv span{display:block;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--hps-mut)}
.hps-prog-mid{flex:1;min-width:200px}
.hps-prog-total{font-weight:700;color:var(--hps-ink);margin-bottom:6px}
.hps-prog-track{height:10px;border-radius:10px;background:var(--hps-line);overflow:hidden}
.hps-prog-track i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--hps-acc),var(--hps-acc2));transition:width .5s ease}
.hps-prog-next{font-size:.8rem;color:var(--hps-mut);margin-top:6px}
.hps-badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.hps-badge-item{display:flex;gap:10px;align-items:center;padding:12px 14px;border:1px solid var(--hps-line);border-radius:8px;background:var(--hps-panel);opacity:.5}
.hps-badge-item.hps-got{opacity:1;border-color:var(--hps-acc)}
.hps-badge-ic{font-size:1.4rem}
.hps-badge-tt{font-weight:700;font-size:.9rem;color:var(--hps-ink)}
.hps-badge-ds{font-size:.76rem;color:var(--hps-mut)}
.hps-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--hps-ink);color:var(--hps-bg);padding:12px 20px;border-radius:999px;font-weight:700;font-size:.9rem;opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;z-index:95}
.hps-toast.hps-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* --- news / articles --- */
.hps-posts{display:grid;gap:18px;max-width:760px}
.hps-post{background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;padding:22px 24px}
.hps-post-date{font-size:.78rem;color:var(--hps-mut);text-transform:uppercase;letter-spacing:.05em}
.hps-post h3{margin:6px 0 10px;font-size:1.2rem}
.hps-post p{color:var(--hps-mut)}
.hps-prose{max-width:760px}
.hps-prose p{color:var(--hps-mut);margin-bottom:14px}
.hps-prose h2{margin:26px 0 10px}

/* --- compliance band / strip --- */
.hps-cband{background:var(--hps-panel);border-bottom:1px solid var(--hps-line)}
.hps-cband-in{display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center;padding:12px 20px}
.hps-cpill{font-size:.74rem;font-weight:700;color:var(--hps-acc);border:1px solid var(--hps-acc);border-radius:999px;padding:3px 10px}
.hps-ctext{font-size:.82rem;color:var(--hps-mut)}
.hps-cbar{background:var(--hps-acc);color:var(--hps-bg);text-align:center;padding:8px 16px;font-size:.85rem;font-weight:600}
.hps-heroplay{border:1px solid var(--hps-line);border-radius:8px;background:var(--hps-panel);padding:18px;margin-top:8px}
.hps-heroplay-head h3{margin:2px 0}
.hps-heroplay-head p{color:var(--hps-mut);margin:0 0 10px;font-size:.92rem}
.hps-heroplay-tag{font-size:.72rem;font-weight:700;color:var(--hps-acc2);text-transform:uppercase;letter-spacing:.06em}
.hps-onboard{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--hps-ink);color:var(--hps-bg);padding:11px 18px;border-radius:12px;font-size:.9rem;font-weight:600;max-width:320px;z-index:70;box-shadow:0 12px 30px rgba(0,0,0,.3)}
.hps-onboard button{margin-left:10px;background:none;border:none;color:var(--hps-acc);font-weight:700;cursor:pointer}
/* --- T2 app showcase --- */
.hps-appwrap{padding:34px 0}
.hps-appcard{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.hps-appicon{width:84px;height:84px;border-radius:20px;background:var(--hps-acc);color:var(--hps-bg);display:flex;align-items:center;justify-content:center;font-size:2.6rem;font-weight:800;flex-shrink:0}
.hps-appmeta h1{margin:0 0 4px;font-size:clamp(1.6rem,4vw,2.4rem)}
.hps-appsub{color:var(--hps-mut);margin:0 0 8px}
.hps-stars{color:var(--hps-acc2);font-size:1.05rem;margin-bottom:12px}
.hps-star-half{opacity:.4}
.hps-appdl{color:var(--hps-mut);font-size:.82rem;font-weight:400;margin-left:6px}
.hps-approw{display:flex;gap:10px;flex-wrap:wrap}
.hps-shots{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px}
.hps-shot{flex:0 0 130px;height:200px;border-radius:18px;border:1px solid var(--hps-line);background:var(--hps-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:14px;text-align:center}
.hps-shot-emoji{font-size:2.6rem}
.hps-shot span{font-size:.82rem;color:var(--hps-ink);font-weight:600}
/* --- T3 lobby --- */
.hps-lobbyhead{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}
.hps-chips{display:flex;gap:8px;flex-wrap:wrap}
.hps-chip{font-size:.82rem;font-weight:600;color:var(--hps-ink);text-decoration:none;border:1px solid var(--hps-line);border-radius:999px;padding:6px 12px;background:var(--hps-panel)}
.hps-chip:hover{border-color:var(--hps-acc)}
.hps-lobby{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:16px}
.hps-tile{display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center;padding:20px 12px;border:1px solid var(--hps-line);border-radius:8px;background:var(--hps-panel);text-decoration:none;transition:transform .18s ease,border-color .18s ease}
.hps-tile:hover{transform:translateY(-4px);border-color:var(--hps-acc)}
.hps-tile-emoji{font-size:2.4rem}
.hps-tile-name{font-weight:700;color:var(--hps-ink);font-size:.92rem}
.hps-tile-cta{font-size:.8rem;font-weight:700;color:var(--hps-acc)}
/* --- T4 mag --- */
.hps-mag{display:grid;grid-template-columns:1.6fr .9fr;gap:26px;align-items:start}
.hps-mag-side{position:sticky;top:16px}
.hps-magcard{background:var(--hps-panel);border:1px solid var(--hps-line);border-radius:8px;padding:18px 20px;margin-bottom:14px}
.hps-magcard h3{margin:6px 0 8px}
.hps-magcard p{color:var(--hps-mut)}
.hps-magtag{font-size:.72rem;font-weight:700;color:var(--hps-acc2);text-transform:uppercase;letter-spacing:.06em}
@media(max-width:760px){.hps-mag{grid-template-columns:1fr}}

/* --- type treatment --- */
.hps-hero h1{letter-spacing:0.02em;text-transform:uppercase;font-weight:800;font-size:clamp(1.84rem,4.6vw,2.76rem)}
.hps-sec h2{letter-spacing:0.02em;text-transform:uppercase;font-weight:800}

.hps-emblem{display:block}

/* --- designed: scroll reveal + spring motion --- */
.hps-anim .hps-reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s cubic-bezier(.34,1.25,.5,1)}
.hps-anim .hps-reveal.hps-in{opacity:1;transform:none}
.hps-hero::before{animation:hps-float 14s ease-in-out infinite alternate}
@keyframes hps-float{from{transform:translate(0,0) scale(1)}to{transform:translate(-16px,12px) scale(1.05)}}
.hps-btn-solid{position:relative;overflow:hidden}
.hps-btn-solid::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg)}
.hps-btn-solid:hover::after{animation:hps-sheen .8s ease}
@keyframes hps-sheen{to{left:140%}}
/* springy hover on cards / tiles / buttons in designed mode */
.hps-anim .hps-card,.hps-anim .hps-game-card,.hps-anim .hps-tile{transition:transform .3s cubic-bezier(.34,1.5,.6,1),border-color .2s ease,box-shadow .25s ease}
.hps-anim .hps-card:hover,.hps-anim .hps-game-card:hover,.hps-anim .hps-tile:hover{transform:translateY(-6px)}
.hps-anim .hps-btn{transition:transform .18s cubic-bezier(.34,1.6,.6,1)}
.hps-anim .hps-btn:hover{transform:translateY(-2px)}
.hps-anim .hps-btn:active{transform:translateY(1px)}
.hps-anim .hps-badge-item{transition:transform .3s ease,opacity .3s ease,border-color .3s ease}
.hps-anim .hps-badge-item.hps-got{transform:translateY(-2px)}
@media (prefers-reduced-motion: reduce){
  .hps-anim .hps-reveal{opacity:1;transform:none;transition:none}
  .hps-hero::before{animation:none}
  .hps-btn-solid:hover::after{animation:none}
}
