/* ============================================================================
   pw.css — Persistent Worlds Design System (component foundation)
   The code counterpart to the Design Bible. Every surface imports this so the
   whole product feels like one world. Namespaced `pw-` to avoid collisions.
   v1 — derived from the World Surface (/inside) language; reconcile with the
   written Design Bible as it lands.
   Design law: every click reveals another entity. Optimise for "explore further".
   ============================================================================ */

:root{
  /* ----- colour ----- */
  --pw-bg:#0c0a09; --pw-panel:#16110f; --pw-panel-2:#1d1714;
  --pw-line:rgba(255,255,255,.08); --pw-line-2:rgba(255,255,255,.14);
  --pw-ink:#f5f1ec; --pw-muted:#9b938c;
  --pw-orange:#ff6a1a; --pw-rose:#ff4d6d; --pw-gold:#e3b341; --pw-good:#1ec773;
  /* ----- type ----- */
  --pw-font:'Inter',system-ui,-apple-system,sans-serif;
  --pw-script:'Great Vibes',cursive;
  /* ----- spacing scale ----- */
  --pw-1:.25rem; --pw-2:.5rem; --pw-3:.75rem; --pw-4:1rem; --pw-5:1.5rem; --pw-6:2rem; --pw-8:3rem;
  /* ----- radius / elevation ----- */
  --pw-r:12px; --pw-r-lg:16px; --pw-r-pill:999px;
  --pw-shadow:0 1px 0 rgba(255,255,255,.03) inset;
}

/* ----- base ----- */
.pw{background:var(--pw-bg);color:var(--pw-ink);font-family:var(--pw-font);
    line-height:1.45;-webkit-font-smoothing:antialiased}
.pw *{box-sizing:border-box}
.pw a{color:inherit;text-decoration:none}
.pw-wrap{max-width:1240px;margin:0 auto;padding:0 20px}
.pw-wrap--wide{max-width:1560px}
.pw-o{color:var(--pw-orange)} .pw-muted{color:var(--pw-muted)}

/* ----- typography ----- */
.pw-h1{font-size:clamp(2rem,3.6vw,3.1rem);font-weight:800;line-height:1.02;letter-spacing:-.01em}
.pw-h2{font-size:1.5rem;font-weight:800}
.pw-h3{font-size:1.05rem;font-weight:800}
.pw-label{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--pw-orange)}
.pw-kicker{font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--pw-orange)}
.pw-sub{color:var(--pw-muted);font-size:.9rem}
.pw-tiny{font-size:.72rem;color:var(--pw-muted)}

/* ----- logo (cursive; matched to landing-page .logo: 1.6rem / .55rem tld) ----- */
.pw-logo{font-family:var(--pw-script);font-size:1.6rem;color:#fff;line-height:1;white-space:nowrap}
.pw-logo .s{color:var(--pw-orange)}
.pw-logo .tld{font-family:var(--pw-font);font-size:.55rem;color:var(--pw-orange);vertical-align:super;letter-spacing:.05em}

/* ----- buttons ----- */
.pw-btn{display:inline-block;border-radius:10px;padding:.7rem 1.3rem;font:inherit;font-weight:800;
        cursor:pointer;border:1px solid var(--pw-line-2);color:var(--pw-ink);background:transparent;
        font-size:.95rem;transition:filter .15s,background .15s}
.pw-btn:hover{background:rgba(255,255,255,.05)}
.pw-btn--primary{background:var(--pw-orange);border-color:var(--pw-orange);color:#fff}
.pw-btn--primary:hover{filter:brightness(1.08);background:var(--pw-orange)}

/* ----- pills / tags / heat ----- */
.pw-pill{display:inline-block;background:var(--pw-orange);color:#fff;font-size:.7rem;font-weight:800;
         border-radius:var(--pw-r-pill);padding:.05rem .5rem;vertical-align:middle}
.pw-tag{font-size:.62rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--pw-orange)}
.pw-heat{color:var(--pw-orange);font-weight:800;font-size:.85rem;white-space:nowrap}
.pw-stars{color:var(--pw-gold);letter-spacing:2px}

/* ----- cards ----- */
.pw-card{background:var(--pw-panel);border:1px solid var(--pw-line);border-radius:var(--pw-r-lg);
         padding:20px;box-shadow:var(--pw-shadow)}
.pw-card--hot{box-shadow:0 0 0 1px rgba(255,106,26,.18)}
.pw-card--glass{background:rgba(22,17,15,.92);backdrop-filter:blur(4px)}

/* ----- clickable (design law: every click reveals an entity) ----- */
.pw-clk{cursor:pointer;transition:background .15s,transform .15s,box-shadow .15s}
.pw-clk:hover{background:rgba(255,255,255,.05)}
.pw-card.pw-clk:hover{box-shadow:0 0 0 1px rgba(255,106,26,.4);transform:translateY(-2px)}

/* ----- avatars / faces ----- */
.pw-avatars{display:flex}
.pw-avatars .pw-av{width:32px;height:32px;border-radius:50%;border:2px solid var(--pw-bg);
                   margin-left:-9px;overflow:hidden;background:var(--pw-panel-2);flex:0 0 auto}
.pw-avatars .pw-av:first-child{margin-left:0}
.pw-face{width:32px;height:32px;border-radius:50%;overflow:hidden;flex:0 0 32px;background:var(--pw-panel-2)}
.pw-av img,.pw-face img{width:100%;height:100%;object-fit:cover;display:block}

/* ----- header / nav ----- */
.pw-header{position:sticky;top:0;z-index:10;background:rgba(12,10,9,.92);backdrop-filter:blur(8px);
           border-bottom:1px solid var(--pw-line)}
.pw-header .pw-bar{display:flex;align-items:center;gap:28px;height:64px}
.pw-nav{display:flex;gap:22px;margin-left:10px;flex:1}
.pw-nav a{font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--pw-muted)}
.pw-nav a.is-active{color:var(--pw-orange);border-bottom:2px solid var(--pw-orange);padding-bottom:21px}

/* ----- hero (cinematic photo + brightened bg + left-dark gradient) -----
   Usage: <section class="pw-hero" style="--pw-hero:url('/static/x.png')">…</section> */
.pw-hero{position:relative;padding:40px 0 34px;min-height:520px;overflow:hidden}
.pw-hero::before{content:"";position:absolute;inset:0;z-index:0;
        background:var(--pw-hero) center/cover no-repeat;filter:brightness(1.5) contrast(1.05) saturate(1.15)}
.pw-hero::after{content:"";position:absolute;inset:0;z-index:0;
        background:linear-gradient(90deg, rgba(12,10,9,.88) 0%, rgba(12,10,9,.45) 20%, rgba(12,10,9,0) 42%),
                   linear-gradient(0deg, rgba(12,10,9,.45) 0%, rgba(12,10,9,0) 24%)}
.pw-hero > *{position:relative;z-index:1}

/* ----- stat strip ----- */
.pw-scale{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;
          background:var(--pw-panel);border:1px solid var(--pw-line);border-radius:var(--pw-r-lg);
          padding:18px 24px;margin:24px 0}
.pw-stat{display:flex;align-items:center;gap:12px;min-width:150px}
.pw-stat .pw-ic{font-size:1.3rem;width:2.4rem;height:2.4rem;border-radius:50%;background:var(--pw-panel-2);
                display:flex;align-items:center;justify-content:center}
.pw-stat .pw-n{font-size:1.7rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.pw-stat .pw-l{font-size:.7rem;color:var(--pw-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}

/* ----- rows / feed lines ----- */
.pw-row{display:flex;gap:.6rem;align-items:flex-start;padding:.55rem 0;border-bottom:1px solid var(--pw-line)}
.pw-row:last-child{border-bottom:0}
.pw-row .pw-body{flex:1;font-size:.88rem}
.pw-row .pw-nm{font-weight:800}
.pw-row .pw-ago{font-size:.7rem;color:var(--pw-muted);white-space:nowrap}

/* ----- timeline step (Story-so-far / history) ----- */
.pw-step{display:flex;gap:.7rem;align-items:flex-start;padding:.3rem 0}
.pw-step .pw-i{width:1.3rem;text-align:center;flex:0 0 1.3rem;font-size:.95rem}
.pw-step .pw-when{font-size:.72rem;color:var(--pw-muted)}

/* ----- columns grid ----- */
.pw-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

/* ----- responsive ----- */
@media(max-width:980px){.pw-cols{grid-template-columns:1fr 1fr}.pw-nav{display:none}}
@media(max-width:620px){.pw-cols{grid-template-columns:1fr}}
