*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#b8965f;--gold-b:#d4aa70;--cream:#f0ead8;
  --muted:rgba(240,234,216,.42);--faint:rgba(240,234,216,.16);
}
html,body{width:100%;height:100%;overflow:hidden}
body{background:#070706;display:flex;align-items:center;justify-content:center;font-family:'Geist Mono',monospace;cursor:none}

/* cursor */
#cur-dot{position:fixed;z-index:9999;pointer-events:none;width:5px;height:5px;border-radius:50%;background:var(--gold-b);transform:translate(-50%,-50%)}
#cur-ring{position:fixed;z-index:9998;pointer-events:none;width:30px;height:30px;border-radius:50%;border:1px solid rgba(184,150,95,.4);transform:translate(-50%,-50%);transition:width .25s,height .25s,border-color .25s,left .1s,top .1s}
body.hover #cur-ring{width:44px;height:44px;border-color:rgba(212,170,112,.9)}

/* tetris canvas sits behind everything */
#tc{position:fixed;inset:0;z-index:0}

/* card backdrop */
.backdrop{
  position:fixed;inset:0;z-index:1;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.card-glass{
  width:min(520px,90vw);
  background:rgba(7,6,5,.72);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(184,150,95,.18);
  border-radius:3px;
  padding:48px 52px 44px;
  pointer-events:all;
  position:relative;
  box-shadow:0 0 80px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.03);
}
.card-glass::before{
  content:'';position:absolute;top:0;left:52px;right:52px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* mark */
.mark{display:flex;align-items:center;gap:14px;margin-bottom:44px;opacity:0;animation:fadeUp .8s cubic-bezier(.22,1,.36,1) .3s forwards}
.monogram{
  width:40px;height:40px;border:1px solid var(--gold);flex-shrink:0;position:relative;
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:16px;font-style:italic;color:var(--gold);
}
.monogram::before,.monogram::after{content:'';position:absolute;background:#070706;height:1px;width:6px}
.monogram::before{top:-1px;left:6px}.monogram::after{bottom:-1px;right:6px}
.mark-meta{font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);line-height:1.5;font-weight:300}
.mark-meta span{display:block;color:var(--gold);margin-top:2px}

/* name */
.name-first{
  display:block;font-family:'Cormorant Garamond',serif;
  font-size:clamp(46px,10vw,72px);font-weight:300;line-height:.93;letter-spacing:-.02em;color:var(--cream);
  clip-path:inset(0 0 100% 0);animation:reveal .9s cubic-bezier(.22,1,.36,1) .62s forwards;
}
.name-first .el{color:var(--gold-b);font-style:italic}
.name-last{
  display:block;font-size:clamp(11px,2.2vw,14px);letter-spacing:.34em;text-transform:uppercase;
  color:var(--muted);font-weight:200;margin-top:10px;
  clip-path:inset(0 0 100% 0);animation:reveal .9s cubic-bezier(.22,1,.36,1) .8s forwards;
}
.rule{height:1px;background:linear-gradient(90deg,var(--gold),transparent);width:0;margin:28px 0;animation:growLine 1.2s cubic-bezier(.22,1,.36,1) 1.1s forwards}
.tagline{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  font-size:clamp(14px,2.2vw,17px);color:var(--muted);line-height:1.7;max-width:360px;margin-bottom:30px;
  opacity:0;animation:fadeUp .7s ease 1.3s forwards;
}
.status{
  display:inline-flex;align-items:center;gap:8px;margin-bottom:26px;
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  opacity:0;animation:fadeUp .7s ease 1.45s forwards;
}
.sdot{width:6px;height:6px;border-radius:50%;background:#4caf7d;animation:pulse 2.5s ease 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(76,175,125,.5)}60%{box-shadow:0 0 0 7px rgba(76,175,125,0)}100%{box-shadow:0 0 0 0 rgba(76,175,125,0)}}
.links{display:flex;flex-wrap:wrap;align-items:center;opacity:0;animation:fadeUp .7s ease 1.6s forwards}
.links a{
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);
  text-decoration:none;padding:8px 16px 8px 0;position:relative;transition:color .3s;font-weight:300;
}
.links a::after{content:'';position:absolute;bottom:4px;left:0;width:0;height:1px;background:var(--gold);transition:width .35s cubic-bezier(.22,1,.36,1)}
.links a:hover{color:var(--cream)}.links a:hover::after{width:calc(100% - 16px)}
.sep{color:var(--faint);font-size:10px;padding-right:10px}

/* HUD */
.hud{
  position:fixed;z-index:2;top:24px;right:24px;
  font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(184,150,95,.5);
  text-align:right;line-height:2;
  opacity:0;animation:fadeIn 1s ease 2s forwards;
}
.hud strong{display:block;font-size:18px;font-weight:300;letter-spacing:.05em;color:rgba(184,150,95,.8);line-height:1}

/* controls hint */
.hint{
  position:fixed;z-index:2;bottom:22px;left:50%;transform:translateX(-50%);
  font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:rgba(184,150,95,.3);
  white-space:normal;max-width:min(92vw,840px);text-align:center;line-height:1.5;
  opacity:0;animation:fadeIn 1s ease 2.4s forwards;
}

/* game over banner */
#gameover{
  display:none;position:fixed;z-index:3;top:50%;left:50%;transform:translate(-50%,-50%);
  background:rgba(7,6,5,.9);border:1px solid rgba(184,150,95,.3);
  padding:24px 40px;text-align:center;border-radius:2px;
}
#gameover p{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
#gameover button{
  font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  background:none;border:1px solid rgba(184,150,95,.4);color:var(--muted);padding:8px 20px;cursor:none;
  transition:color .2s,border-color .2s;
}
#gameover button:hover{color:var(--cream);border-color:var(--gold)}

/* stamp */
.stamp{position:fixed;bottom:26px;right:28px;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:rgba(184,150,95,.18);writing-mode:vertical-rl;opacity:0;animation:fadeIn 1s ease 2.1s forwards}

@keyframes fadeUp{from{opacity:0;transform:translateY(13px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}
@keyframes reveal{to{clip-path:inset(0 0 0% 0)}}
@keyframes growLine{to{width:100px}}

@media(max-width:600px){
  .hint{display:none}
  .card-glass{padding:36px 28px 32px}
  .card-glass::before{left:28px;right:28px}
  .hud{top:12px;right:12px}
  .stamp{display:none}
}

/* ── NEWS TICKER ── */
#ticker-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:10;
  height:38px;
  background:rgba(6,5,4,.92);
  border-top:1px solid rgba(184,150,95,.22);
  display:flex;align-items:center;
  overflow:hidden;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:1;
}
.ticker-label{
  flex-shrink:0;display:flex;align-items:center;gap:8px;
  padding:0 14px 0 16px;
  border-right:1px solid rgba(184,150,95,.18);
  height:100%;
  background:rgba(184,150,95,.07);
}
.ticker-live{
  width:7px;height:7px;border-radius:50%;background:#e05252;flex-shrink:0;
  animation:livePulse 1.4s ease infinite;
}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.35}}
.ticker-cat{
  font-size:8px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:400;white-space:nowrap;
}
.ticker-track{
  flex:1;overflow:hidden;height:100%;position:relative;
}
.ticker-inner{
  display:flex;align-items:center;height:100%;
  white-space:nowrap;will-change:transform;
  position:absolute;left:0;top:0;
}
.ticker-item{
  display:inline-flex;align-items:center;gap:0;
  font-size:10px;letter-spacing:.06em;color:rgba(240,234,216,.65);
  font-weight:300;padding:0 6px;
  transition:color .2s;
}
.ticker-item:hover{color:var(--cream)}
.ticker-item a{color:inherit;text-decoration:none}
.ticker-bullet{
  display:inline-block;width:4px;height:4px;border-radius:50%;
  background:rgba(184,150,95,.45);margin:0 18px;flex-shrink:0;vertical-align:middle;
}
.ticker-time{
  flex-shrink:0;padding:0 14px;
  font-size:9px;letter-spacing:.14em;color:rgba(184,150,95,.4);
  border-left:1px solid rgba(184,150,95,.18);height:100%;
  display:flex;align-items:center;white-space:nowrap;
}
.ticker-loading{
  font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(184,150,95,.35);padding:0 20px;
  animation:blink 1.2s ease infinite;
}
@keyframes blink{0%,100%{opacity:.35}50%{opacity:.9}}
@media(max-width:600px){
  #ticker-bar{height:34px}
  .ticker-label{display:none}
  .ticker-cat{display:none}
  .ticker-item{font-size:9px}
  .ticker-time{display:none}
}

@media (hover:none) and (pointer:coarse){
  body,
  #gameover button{
    cursor:auto;
  }

  #cur-dot,
  #cur-ring{
    display:none;
  }
}
