﻿*{margin:0;padding:0;box-sizing:border-box}
*::selection{background:#fff;color:#000}

:root{
  --bg:#000;
  --fg:#f4f1ea;
  --fg-dim:rgba(244,241,234,.55);
  --fg-faint:rgba(244,241,234,.18);
  --line:rgba(244,241,234,.12);
  --line-strong:rgba(244,241,234,.35);
  --ink:#0a0a0c;
  --warm:#e8d9b8;
  --display:'Cinzel',serif;
  --serif:'Cormorant Garamond',serif;
  --mono:'IBM Plex Mono',monospace;
}

html{scroll-behavior:smooth}
html,body{
  background:#000;
  color:var(--fg);
  font-family:var(--mono);
  font-weight:300;
  overflow-x:hidden;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body{position:relative}

/* ==========================================================
   BACKGROUND VIDEO
   ========================================================== */
.bg-video{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-3;
  opacity:.85;
  filter:saturate(.8) contrast(1.05);
}
.bg-overlay{
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(0,0,0,.3) 0%, rgba(0,0,0,.7) 60%),
    radial-gradient(ellipse at 70% 80%, rgba(0,0,0,.4) 0%, rgba(0,0,0,.85) 70%),
    linear-gradient(180deg, rgba(0,0,0,.4) 0%, rgba(0,0,0,.6) 50%, rgba(0,0,0,.8) 100%);
  pointer-events:none;
}
.bg-grain{
  position:fixed;
  inset:0;
  z-index:-1;
  opacity:.08;
  pointer-events:none;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' seed='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.bg-vignette{
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.6) 100%);
}

.scanlines{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:5;
  background:repeating-linear-gradient(
    0deg,
    rgba(0,0,0,.1) 0px,
    rgba(0,0,0,.1) 1px,
    transparent 1px,
    transparent 3px
  );
  opacity:.4;
  mix-blend-mode:multiply;
}

/* ==========================================================
   LOADER
   ========================================================== */
#loader{
  position:fixed;
  inset:0;
  background:#000;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity 1s cubic-bezier(.7,0,.3,1), visibility 1s;
  overflow:hidden;
  padding:20px;
}
#loader.hidden{opacity:0;visibility:hidden}

.loader-noise{
  position:absolute;
  inset:0;
  opacity:.12;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.loader-stars{position:absolute;inset:0}
.loader-stars .s{
  position:absolute;
  background:#fff;
  border-radius:50%;
  animation:twinkle 3s ease-in-out infinite;
}
@keyframes twinkle{
  0%,100%{opacity:.15;transform:scale(.8)}
  50%{opacity:.95;transform:scale(1.4)}
}

.loader-content{
  position:relative;
  text-align:center;
  z-index:2;
  width:100%;
  max-width:480px;
}

.loader-cross{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:340px;
  height:340px;
  pointer-events:none;
  opacity:.4;
  max-width:90vw;
  max-height:90vw;
}
.loader-cross span{
  position:absolute;
  background:linear-gradient(180deg,transparent,rgba(244,241,234,.4),transparent);
}
.loader-cross span:first-child{
  left:50%;top:0;width:1px;height:100%;
  transform:translateX(-50%);
}
.loader-cross span:last-child{
  top:50%;left:0;height:1px;width:100%;
  background:linear-gradient(90deg,transparent,rgba(244,241,234,.4),transparent);
  transform:translateY(-50%);
}

.loader-img-wrap{
  position:relative;
  width:160px;
  height:160px;
  margin:0 auto 40px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.loader-img-ring{
  position:absolute;
  inset:-12px;
  border-radius:50%;
  border:1px solid rgba(244,241,234,.2);
  border-top-color:var(--fg);
  border-right-color:var(--fg);
  animation:rotate 2.4s linear infinite;
  box-shadow:0 0 30px rgba(244,241,234,.15);
  will-change:transform;
}

.loader-img-orbit{
  position:absolute;
  inset:-26px;
  border-radius:50%;
  border:1px dashed rgba(244,241,234,.25);
  animation:rotate 16s linear infinite reverse;
  will-change:transform;
}
.loader-img-orbit::before{
  content:"";
  position:absolute;
  top:-4px;
  left:50%;
  transform:translateX(-50%);
  width:8px;
  height:8px;
  background:var(--warm);
  border-radius:50%;
  box-shadow:0 0 14px var(--warm);
}

.loader-img-core{
  width:100%;
  height:100%;
  border-radius:50%;
  background:#0a0a0a;
  overflow:hidden;
  border:2px solid var(--fg);
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:
    0 0 40px rgba(244,241,234,.25),
    0 0 80px rgba(232,217,184,.15),
    inset 0 0 25px rgba(0,0,0,.6);
  animation:pulseImg 3s ease-in-out infinite;
}
@keyframes pulseImg{
  0%,100%{box-shadow:0 0 40px rgba(244,241,234,.25), 0 0 80px rgba(232,217,184,.15), inset 0 0 25px rgba(0,0,0,.6)}
  50%{box-shadow:0 0 60px rgba(244,241,234,.45), 0 0 120px rgba(232,217,184,.25), inset 0 0 25px rgba(0,0,0,.6)}
}

.loader-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:contrast(1.05);
}

.loader-img-fallback{
  display:none;
  width:100%;
  height:100%;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-weight:900;
  font-size:54px;
  letter-spacing:4px;
  color:var(--fg);
  background:radial-gradient(circle at 35% 35%, #2a2a2a 0%, #050505 70%);
}

.loader-title{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(36px,8vw,54px);
  letter-spacing:clamp(8px,2vw,14px);
  color:var(--fg);
  margin-bottom:8px;
  text-shadow:0 0 40px rgba(244,241,234,.3);
}
.loader-sub{
  font-family:var(--mono);
  font-size:clamp(8px,2.2vw,9px);
  letter-spacing:clamp(3px,1vw,6px);
  color:var(--fg-dim);
  margin-bottom:30px;
}
.loader-bar{
  width:min(280px,80vw);
  height:1px;
  background:rgba(244,241,234,.15);
  margin:0 auto 14px;
  position:relative;
  overflow:hidden;
}
.loader-bar-fill{
  position:absolute;
  inset:0 100% 0 0;
  background:var(--fg);
  transition:right .3s ease;
  box-shadow:0 0 20px rgba(244,241,234,.6);
}
.loader-meta{
  font-size:10px;
  letter-spacing:4px;
  color:var(--fg-dim);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.loader-dot{opacity:.4}

/* ==========================================================
   TOPBAR
   ========================================================== */
.topbar{
  position:fixed;
  top:0;left:0;right:0;
  padding:22px 36px;
  padding-top:max(22px, env(safe-area-inset-top, 22px));
  padding-left:max(36px, env(safe-area-inset-left, 36px));
  padding-right:max(36px, env(safe-area-inset-right, 36px));
  display:flex;
  justify-content:space-between;
  align-items:center;
  z-index:50;
  pointer-events:none;
  gap:12px;
}
.topbar > *{pointer-events:auto}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--display);
  font-weight:700;
  font-size:13px;
  letter-spacing:5px;
  color:var(--fg);
}
.brand-mark{font-size:18px;color:var(--warm)}

.status-pill{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:9px;
  letter-spacing:3px;
  color:var(--fg-dim);
  border:1px solid var(--line);
  padding:6px 14px;
  background:rgba(0,0,0,.4);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.status-dot{
  width:6px;height:6px;
  border-radius:50%;
  background:var(--fg);
  box-shadow:0 0 8px var(--fg);
  animation:pulseDot 2s infinite;
  flex-shrink:0;
}
@keyframes pulseDot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.8)}
}

.topbar-meta{
  font-size:10px;
  letter-spacing:3px;
  color:var(--fg-dim);
  white-space:nowrap;
}

/* ==========================================================
   SIDE TEXT
   ========================================================== */
.side-left,.side-right{
  position:fixed;
  top:0;
  height:100vh;
  width:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:40;
  pointer-events:none;
}
.side-left{left:0}
.side-right{right:0}
.side-text{
  font-size:9px;
  letter-spacing:6px;
  color:var(--fg-faint);
  writing-mode:vertical-rl;
  transform:rotate(180deg);
}
.side-right .side-text{transform:rotate(0)}

/* ==========================================================
   HERO
   ========================================================== */
.hero{
  min-height:100vh;
  position:relative;
  padding:120px 60px 80px;
  display:flex;
  align-items:center;
  overflow:hidden;
}

.hero-grid{
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(244,241,234,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(244,241,234,.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, #000 20%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 20%, transparent 75%);
}

.hero-marker{
  position:absolute;
  font-size:9px;
  letter-spacing:3px;
  color:var(--fg-dim);
  pointer-events:none;
}
.hero-marker-tl{top:90px;left:50px}
.hero-marker-tr{top:90px;right:50px}
.hero-marker-bl{bottom:50px;left:50px}
.hero-marker-br{bottom:50px;right:50px}

.hero-inner{
  width:100%;
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:80px;
  align-items:center;
  position:relative;
  z-index:2;
}

.kicker{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:30px;
  animation:fadeUp 1s ease .6s both;
}
.kicker-line{
  width:50px;height:1px;background:var(--fg);
}
.kicker-text{
  font-size:10px;
  letter-spacing:4px;
  color:var(--fg);
}

.ghost-text{
  position:absolute;
  top:-40px;
  left:-20px;
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(120px,18vw,260px);
  letter-spacing:-4px;
  color:transparent;
  -webkit-text-stroke:1px rgba(244,241,234,.06);
  pointer-events:none;
  user-select:none;
  z-index:0;
  white-space:nowrap;
}

.hero-name{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(64px,11vw,180px);
  line-height:.85;
  letter-spacing:-3px;
  margin-bottom:30px;
  position:relative;
  z-index:1;
  animation:fadeUp 1s ease .8s both;
}
.hero-name-row{display:block}
.hero-name-row-2{
  margin-left:clamp(20px,8vw,80px);
}
.hero-name-word{
  display:inline-block;
  position:relative;
}
.hero-name-word::before{
  content:attr(data-text);
  position:absolute;
  inset:0;
  color:transparent;
  -webkit-text-stroke:1px rgba(244,241,234,.4);
  transform:translate(3px,3px);
  pointer-events:none;
}
.hero-name-word.italic{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  letter-spacing:-2px;
}

.hero-tags{
  display:flex;
  align-items:center;
  gap:14px;
  font-size:11px;
  letter-spacing:4px;
  color:var(--fg);
  margin-bottom:36px;
  flex-wrap:wrap;
  animation:fadeUp 1s ease 1s both;
}
.tag-sep{color:var(--fg-faint)}

.hero-bio{
  font-family:var(--serif);
  font-size:clamp(18px,2.2vw,22px);
  line-height:1.55;
  font-weight:300;
  color:var(--fg);
  max-width:480px;
  margin-bottom:40px;
  animation:fadeUp 1s ease 1.2s both;
}
.hero-bio em{
  font-style:italic;
  color:var(--warm);
}

.hero-cta-row{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:30px;
  animation:fadeUp 1s ease 1.4s both;
}

.btn-ghost{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 26px;
  border:1px solid var(--fg);
  font-size:10px;
  letter-spacing:4px;
  color:var(--fg);
  text-decoration:none;
  background:transparent;
  position:relative;
  overflow:hidden;
  transition:color .4s ease;
  cursor:pointer;
  min-height:44px;
}
.btn-ghost::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--fg);
  transform:translateX(-101%);
  transition:transform .4s cubic-bezier(.7,0,.3,1);
  z-index:0;
}
.btn-ghost:hover{color:var(--ink)}
.btn-ghost:hover::before{transform:translateX(0)}
.btn-ghost > *{position:relative;z-index:1}
.btn-ghost-2{
  border-color:var(--warm);
  color:var(--warm);
}
.btn-ghost-2::before{background:var(--warm)}

.hero-coords{
  display:inline-flex;
  flex-direction:column;
  gap:4px;
  padding-left:24px;
  border-left:1px solid var(--line-strong);
  animation:fadeUp 1s ease 1.6s both;
}
.coord-label{font-size:9px;letter-spacing:3px;color:var(--fg-dim)}
.coord-val{font-size:11px;letter-spacing:2px;color:var(--fg)}

.hero-right{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}

.profile-stage{
  position:relative;
  width:min(440px,90vw);
  aspect-ratio:1;
  display:flex;
  align-items:center;
  justify-content:center;
  animation:fadeUp 1.2s ease 1s both;
}

.profile-tape{
  position:absolute;
  left:-20px;
  right:-20px;
  height:22px;
  background:var(--fg);
  color:var(--ink);
  font-size:9px;
  font-weight:700;
  letter-spacing:3px;
  display:flex;
  align-items:center;
  padding:0 14px;
  white-space:nowrap;
  overflow:hidden;
  z-index:5;
  box-shadow:0 4px 20px rgba(0,0,0,.5);
}
.profile-tape-top{
  top:30px;
  transform:rotate(-3deg);
}
.profile-tape-bottom{
  bottom:30px;
  transform:rotate(2deg);
}

.profile-rune{
  position:absolute;
  font-size:14px;
  color:var(--fg-dim);
  z-index:4;
  animation:runeFloat 4s ease-in-out infinite;
}
.profile-rune-tl{top:8%;left:8%;animation-delay:0s}
.profile-rune-tr{top:8%;right:8%;animation-delay:1s}
.profile-rune-bl{bottom:8%;left:8%;animation-delay:2s}
.profile-rune-br{bottom:8%;right:8%;animation-delay:3s}
@keyframes runeFloat{
  0%,100%{transform:translateY(0);opacity:.4}
  50%{transform:translateY(-6px);opacity:1}
}

.profile-orbit{
  position:absolute;
  border-radius:50%;
  pointer-events:none;
}
.profile-orbit-1{
  inset:8%;
  border:1px dashed rgba(244,241,234,.25);
  animation:rotate 30s linear infinite;
  will-change:transform;
}
.profile-orbit-1::before{
  content:"";
  position:absolute;
  top:-3px;left:50%;
  width:6px;height:6px;
  background:var(--fg);
  border-radius:50%;
  transform:translateX(-50%);
  box-shadow:0 0 12px var(--fg);
}
.profile-orbit-2{
  inset:0;
  border:1px solid rgba(244,241,234,.1);
  animation:rotate 60s linear infinite reverse;
  will-change:transform;
}
.profile-orbit-2::before,
.profile-orbit-2::after{
  content:"";
  position:absolute;
  background:var(--fg);
  width:4px;height:4px;
  border-radius:50%;
}
.profile-orbit-2::before{top:0;left:50%;transform:translateX(-50%)}
.profile-orbit-2::after{bottom:0;left:50%;transform:translateX(-50%);background:var(--warm)}

.profile-orbit-3{
  inset:-8%;
  border:1px solid rgba(244,241,234,.04);
  animation:rotate 80s linear infinite;
  will-change:transform;
}
.profile-orbit-3::before{
  content:"✦";
  position:absolute;
  top:-10px;left:50%;
  transform:translateX(-50%);
  color:var(--fg);
  font-size:14px;
}

@keyframes rotate{to{transform:rotate(360deg)}}

.profile-halo{
  position:absolute;
  inset:15%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(244,241,234,.15) 0%, transparent 70%);
  filter:blur(20px);
  animation:halo 4s ease-in-out infinite;
}
@keyframes halo{
  0%,100%{opacity:.5;transform:scale(1)}
  50%{opacity:.9;transform:scale(1.1)}
}

.profile-frame{
  position:relative;
  width:62%;
  height:62%;
  border-radius:50%;
  padding:3px;
  background:
    conic-gradient(
      from 0deg,
      transparent 0deg,
      var(--fg) 45deg,
      transparent 90deg,
      var(--warm) 180deg,
      transparent 225deg,
      var(--fg) 315deg,
      transparent 360deg
    );
  animation:rotate 8s linear infinite;
  z-index:3;
  will-change:transform;
}
.profile-frame-inner{
  width:100%;
  height:100%;
  border-radius:50%;
  background:#0a0a0a;
  overflow:hidden;
  position:relative;
  animation:rotate 8s linear infinite reverse;
  will-change:transform;
  box-shadow:
    0 0 80px rgba(244,241,234,.25),
    0 0 140px rgba(232,217,184,.12),
    inset 0 0 30px rgba(0,0,0,.6);
}
.profile-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:contrast(1.05) saturate(.95);
}
.profile-frame-inner.no-image .profile-img{display:none}
.profile-frame-inner.no-image .profile-fallback{display:flex}

.profile-fallback{
  position:absolute;
  inset:0;
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  color:var(--fg-dim);
  background:
    radial-gradient(circle at 35% 30%, #1a1a1a 0%, #050505 70%),
    repeating-linear-gradient(45deg,#0a0a0a 0,#0a0a0a 2px,#020202 2px,#020202 8px);
}
.profile-fallback svg{width:60px;height:60px;opacity:.5}
.profile-fallback-text{
  font-size:10px;
  letter-spacing:3px;
  color:var(--fg-dim);
}

.profile-scan{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(244,241,234,.15) 50%,transparent 60%);
  animation:scan 4s linear infinite;
  pointer-events:none;
  will-change:transform;
}
@keyframes scan{
  0%{transform:translateY(-100%)}
  100%{transform:translateY(100%)}
}

.profile-corner{
  position:absolute;
  width:24px;
  height:24px;
  border:1px solid var(--fg);
  z-index:3;
}
.profile-corner.tl{top:0;left:0;border-right:none;border-bottom:none}
.profile-corner.tr{top:0;right:0;border-left:none;border-bottom:none}
.profile-corner.bl{bottom:0;left:0;border-right:none;border-top:none}
.profile-corner.br{bottom:0;right:0;border-left:none;border-top:none}

.profile-stats{
  position:absolute;
  bottom:-50px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  gap:18px;
  padding:14px 24px;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--line);
  z-index:6;
  white-space:nowrap;
  min-width:max-content;
}
.ps-item{text-align:center;min-width:54px}
.ps-num{
  font-family:var(--display);
  font-weight:700;
  font-size:22px;
  letter-spacing:1px;
  color:var(--fg);
  line-height:1;
}
.ps-num.suffix-pct::after{content:"%";font-size:14px;color:var(--fg-dim);margin-left:2px}
.ps-label{
  font-size:8px;
  letter-spacing:3px;
  color:var(--fg-dim);
  margin-top:6px;
}
.ps-divider{
  width:1px;height:24px;
  background:var(--line);
}

.hero-scroll{
  position:absolute;
  bottom:24px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  font-size:9px;
  letter-spacing:4px;
  color:var(--fg-dim);
  z-index:3;
}
.hero-scroll-line{
  width:1px;
  height:40px;
  background:linear-gradient(180deg,var(--fg),transparent);
  animation:scrollLine 2s ease-in-out infinite;
  transform-origin:top;
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(40px)}
  to{opacity:1;transform:translateY(0)}
}

/* ==========================================================
   SECTION RULE
   ========================================================== */
.section-rule{
  display:flex;
  align-items:center;
  gap:24px;
  max-width:1400px;
  margin:0 auto 70px;
}
.section-num{
  font-family:var(--display);
  font-weight:700;
  font-size:14px;
  letter-spacing:4px;
  color:var(--warm);
}
.section-title{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(28px,4vw,46px);
  letter-spacing:8px;
  color:var(--fg);
}
.section-line{
  flex:1;
  height:1px;
  background:linear-gradient(90deg,var(--fg),transparent);
}

/* ==========================================================
   FRIEND CODE SECTION
   ========================================================== */
.friend-code-section{padding:140px 60px;position:relative}

.fcs-inner{
  max-width:700px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:40px;
}

.fcs-frame{
  position:relative;
  width:100%;
  max-width:560px;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow:
    0 0 60px rgba(244,241,234,.08),
    0 0 120px rgba(232,217,184,.05);
  transition:box-shadow .4s ease;
}
.fcs-frame:hover{
  box-shadow:
    0 0 80px rgba(244,241,234,.14),
    0 0 140px rgba(232,217,184,.08);
}

.fcs-frame.fcs-no-img .fcs-img{display:none}
.fcs-frame.fcs-no-img .fcs-fallback{display:flex}

.fcs-img{
  width:100%;
  height:auto;
  display:block;
  filter:contrast(1.02) saturate(.95);
  transition:transform .6s ease;
}
.fcs-frame:hover .fcs-img{transform:scale(1.02)}

.fcs-fallback{
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:80px 40px;
  color:var(--fg-dim);
  font-size:11px;
  letter-spacing:3px;
}

.fcs-scan{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(244,241,234,.06) 50%,transparent 60%);
  animation:scan 6s linear infinite;
  pointer-events:none;
  will-change:transform;
}

.fcs-corner{
  position:absolute;
  width:20px;
  height:20px;
  border:1px solid var(--fg);
  z-index:3;
  pointer-events:none;
}
.fcs-corner.tl{top:8px;left:8px;border-right:none;border-bottom:none}
.fcs-corner.tr{top:8px;right:8px;border-left:none;border-bottom:none}
.fcs-corner.bl{bottom:8px;left:8px;border-right:none;border-top:none}
.fcs-corner.br{bottom:8px;right:8px;border-left:none;border-top:none}

.fcs-meta{
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
}
.fcs-tag{
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  letter-spacing:5px;
  color:var(--warm);
}
.fcs-desc{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(15px,2vw,18px);
  line-height:1.6;
  color:var(--fg-dim);
  max-width:480px;
}
.fcs-desc em{color:var(--warm);font-style:italic}

/* ==========================================================
   DOSSIER
   ========================================================== */
.dossier{padding:140px 60px;position:relative}

.dossier-grid{
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.dossier-card{
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:36px 28px;
  position:relative;
  overflow:hidden;
  min-height:240px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:background .4s ease;
}
.dossier-card::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:0;height:1px;
  background:var(--fg);
  transition:width .5s ease;
}
.dossier-card:hover{background:rgba(20,20,20,.65)}
.dossier-card:hover::before{width:100%}
.dossier-card-num{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:3px;
  color:var(--fg-dim);
}
.dossier-card-title{
  font-family:var(--display);
  font-weight:500;
  font-size:11px;
  letter-spacing:5px;
  color:var(--warm);
  margin-top:auto;
  margin-bottom:14px;
}
.dossier-card-body{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.dossier-card-body .big{
  font-family:var(--display);
  font-weight:900;
  font-size:34px;
  letter-spacing:1px;
  color:var(--fg);
  line-height:1;
}
.dossier-card-body .small{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--fg-dim);
  line-height:1.4;
}

/* ==========================================================
   SKILLSET
   ========================================================== */
.weapons{padding:140px 60px;position:relative}
.skill-list{
  max-width:1100px;
  margin:0 auto;
}
.skill-row{
  display:grid;
  grid-template-columns:240px 1fr 60px;
  align-items:center;
  gap:30px;
  padding:24px 0;
  border-bottom:1px solid var(--line);
}
.skill-row:hover .skill-name{color:var(--warm)}
.skill-name{
  font-family:var(--display);
  font-weight:700;
  font-size:16px;
  letter-spacing:4px;
  color:var(--fg);
  transition:color .3s ease;
}
.skill-track{
  height:1px;
  background:var(--line);
  position:relative;
  overflow:visible;
}
.skill-bar{
  position:absolute;
  left:0;top:50%;
  height:1px;
  width:0;
  background:var(--fg);
  transition:width 1.4s cubic-bezier(.7,0,.3,1);
  transform:translateY(-50%);
  box-shadow:0 0 8px rgba(244,241,234,.5);
}
.skill-bar::after{
  content:"";
  position:absolute;
  right:0;top:50%;
  width:8px;height:8px;
  background:var(--fg);
  border-radius:50%;
  transform:translate(50%,-50%);
  box-shadow:0 0 12px var(--fg);
}
.skill-pct{
  font-family:var(--display);
  font-weight:700;
  font-size:18px;
  letter-spacing:1px;
  color:var(--fg);
  text-align:right;
}
.skill-pct::after{
  content:"%";
  font-size:11px;
  color:var(--fg-dim);
  margin-left:2px;
}

/* ==========================================================
   GALLERY / CAROUSEL
   ========================================================== */
.gallery{
  padding:140px 60px;
  position:relative;
}
.gallery-intro{
  max-width:700px;
  margin:0 auto 60px;
  text-align:center;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(15px,2vw,18px);
  line-height:1.6;
  color:var(--fg-dim);
}

.carousel{
  max-width:1200px;
  margin:0 auto;
  position:relative;
}

.carousel-empty{
  padding:30px 20px;
  text-align:center;
  color:var(--fg-dim);
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  letter-spacing:1px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.cl-spinner{
  width:32px;
  height:32px;
  border:2px solid rgba(244,241,234,.15);
  border-top-color:var(--fg);
  border-radius:50%;
  animation:rotate .9s linear infinite;
}

.carousel-stage{
  position:relative;
  display:flex;
  align-items:center;
  gap:20px;
}

.carousel-arrow{
  flex-shrink:0;
  width:46px;
  height:46px;
  min-height:44px;
  border:1px solid var(--line-strong);
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:var(--fg);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .3s ease;
  z-index:3;
}
.carousel-arrow:hover{
  background:var(--fg);
  color:var(--ink);
  border-color:var(--fg);
}
.carousel-arrow:disabled{
  opacity:.3;
  cursor:not-allowed;
}
.carousel-arrow:disabled:hover{
  background:rgba(0,0,0,.5);
  color:var(--fg);
}

.carousel-viewport{
  flex:1;
  overflow:hidden;
  position:relative;
  background:rgba(0,0,0,.6);
  border:1px solid var(--line);
  aspect-ratio:16/9;
  min-height:280px;
  touch-action:pan-y;
}
.carousel-viewport::before,
.carousel-viewport::after{
  content:"";
  position:absolute;
  top:8px;
  width:18px;
  height:18px;
  border:1px solid var(--fg);
  z-index:4;
  pointer-events:none;
}
.carousel-viewport::before{
  left:8px;
  border-right:none;
  border-bottom:none;
}
.carousel-viewport::after{
  right:8px;
  border-left:none;
  border-bottom:none;
}

.carousel-track{
  display:flex;
  width:100%;
  height:100%;
  transition:transform .6s cubic-bezier(.7,0,.3,1);
  will-change:transform;
}

.carousel-slide{
  flex:0 0 100%;
  width:100%;
  height:100%;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:zoom-in;
  overflow:hidden;
}
.carousel-slide img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  transition:transform .8s ease;
}
.carousel-slide:hover img{transform:scale(1.03)}
.carousel-slide-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.6));
  pointer-events:none;
}
.carousel-slide-label{
  position:absolute;
  bottom:14px;
  left:18px;
  font-size:10px;
  letter-spacing:3px;
  color:var(--fg);
  z-index:2;
  text-shadow:0 2px 8px rgba(0,0,0,.8);
}

.carousel-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:24px;
  padding:0 6px;
  gap:20px;
  flex-wrap:wrap;
}
.carousel-counter{
  font-family:var(--display);
  font-weight:700;
  font-size:18px;
  letter-spacing:3px;
  color:var(--fg);
  display:flex;
  align-items:center;
  gap:8px;
}
.cc-sep{color:var(--fg-faint)}
#carouselTotal{color:var(--fg-dim);font-size:14px}

.carousel-dots{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  flex:1;
  justify-content:center;
  max-width:400px;
}
.carousel-dot{
  width:24px;
  height:2px;
  background:var(--line-strong);
  border:none;
  cursor:pointer;
  transition:all .3s ease;
  padding:0;
  min-height:18px;
}
.carousel-dot.active{
  background:var(--fg);
  width:40px;
  box-shadow:0 0 8px rgba(244,241,234,.5);
}

.carousel-fullscreen{
  background:none;
  border:1px solid var(--line-strong);
  color:var(--fg);
  width:34px;
  height:34px;
  min-height:44px;
  min-width:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .3s ease;
}
.carousel-fullscreen:hover{
  background:var(--fg);
  color:var(--ink);
}

/* ==========================================================
   LIGHTBOX
   ========================================================== */
.lightbox{
  position:fixed;
  inset:0;
  z-index:9000;
  background:rgba(0,0,0,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:60px 80px;
  animation:fadeIn .3s ease;
}
.lightbox[hidden]{display:none}
@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}
.lightbox-content{
  flex:1;
  max-width:1400px;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
}
.lightbox img{
  max-width:100%;
  max-height:calc(100vh - 160px);
  object-fit:contain;
  border:1px solid var(--line);
  box-shadow:0 20px 80px rgba(0,0,0,.8);
  animation:zoomIn .4s ease;
}
@keyframes zoomIn{
  from{opacity:0;transform:scale(.95)}
  to{opacity:1;transform:scale(1)}
}
.lightbox-caption{
  font-size:11px;
  letter-spacing:4px;
  color:var(--fg-dim);
}
.lightbox-close{
  position:absolute;
  top:24px;
  right:24px;
  width:46px;
  height:46px;
  background:none;
  border:1px solid var(--line-strong);
  color:var(--fg);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .3s ease;
  z-index:5;
}
.lightbox-close:hover{
  background:var(--fg);
  color:var(--ink);
  transform:rotate(90deg);
}
.lightbox-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:54px;
  background:rgba(0,0,0,.5);
  border:1px solid var(--line-strong);
  color:var(--fg);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .3s ease;
  z-index:5;
}
.lightbox-arrow:hover{
  background:var(--fg);
  color:var(--ink);
}
.lightbox-prev{left:24px}
.lightbox-next{right:24px}

/* ==========================================================
   QUOTE
   ========================================================== */
.quote-section{
  padding:160px 60px;
  text-align:center;
  position:relative;
  max-width:1100px;
  margin:0 auto;
}
.quote-mark{
  font-family:var(--display);
  font-size:140px;
  line-height:.5;
  color:var(--warm);
  opacity:.5;
  margin-bottom:30px;
  font-style:italic;
}
.big-quote{
  font-family:var(--serif);
  font-weight:300;
  font-style:italic;
  font-size:clamp(24px,4.5vw,52px);
  line-height:1.3;
  letter-spacing:-.5px;
  color:var(--fg);
  margin-bottom:40px;
}
.big-quote em{font-style:italic;color:var(--warm)}
.quote-author{
  font-size:10px;
  letter-spacing:6px;
  color:var(--fg-dim);
}

/* ==========================================================
   LEDGER
   ========================================================== */
.ledger{padding:140px 60px;position:relative}
.ledger-list{
  max-width:1100px;
  margin:0 auto;
  border-top:1px solid var(--line);
}
.ledger-row{
  display:grid;
  grid-template-columns:80px 1fr 140px 120px;
  align-items:center;
  gap:30px;
  padding:22px 16px;
  border-bottom:1px solid var(--line);
  transition:background .3s ease, padding .3s ease;
}
.ledger-row:hover{background:rgba(244,241,234,.03);padding-left:30px}
.lr-id{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:2px;
  color:var(--fg-dim);
}
.lr-name{
  font-family:var(--display);
  font-weight:500;
  font-size:14px;
  letter-spacing:3px;
  color:var(--fg);
}
.lr-date{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:2px;
  color:var(--fg-dim);
}
.lr-status{
  font-size:9px;
  letter-spacing:3px;
  padding:5px 10px;
  border:1px solid var(--line-strong);
  text-align:center;
}
.lr-status.done{
  color:var(--fg);
  background:rgba(244,241,234,.06);
}
.lr-status.pending{
  color:var(--warm);
  border-color:var(--warm);
  background:rgba(232,217,184,.06);
  animation:blink 2s infinite;
}
@keyframes blink{
  0%,100%{opacity:1}
  50%{opacity:.5}
}

/* ==========================================================
   FOOTER
   ========================================================== */
.footer{
  position:relative;
  padding:80px 60px 40px;
  padding-bottom:max(40px, env(safe-area-inset-bottom, 40px));
  border-top:1px solid var(--line);
  overflow:hidden;
}
.footer-bg{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));
  pointer-events:none;
}
.footer-inner{
  position:relative;
  z-index:1;
  max-width:1400px;
  margin:0 auto;
}
.footer-art{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(56px,16vw,200px);
  letter-spacing:6px;
  line-height:.9;
  text-align:center;
  color:transparent;
  -webkit-text-stroke:1px rgba(244,241,234,.25);
  margin-bottom:60px;
  user-select:none;
  position:relative;
}
.footer-art::before{
  content:attr(data-text);
  position:absolute;
  inset:0;
  -webkit-text-stroke:0;
  color:transparent;
  background:linear-gradient(180deg,rgba(244,241,234,.4),transparent 60%);
  -webkit-background-clip:text;
  background-clip:text;
}

.footer-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  padding:30px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:30px;
}
.footer-col{display:flex;flex-direction:column;gap:6px}
.footer-label{
  font-size:9px;
  letter-spacing:3px;
  color:var(--fg-dim);
}
.footer-value{
  font-family:var(--display);
  font-weight:500;
  font-size:13px;
  letter-spacing:2px;
  color:var(--fg);
}

.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:20px;
}
.footer-cred{
  font-size:10px;
  letter-spacing:3px;
  color:var(--fg-dim);
}
.footer-cred-name{
  font-family:var(--display);
  font-weight:900;
  font-size:14px;
  letter-spacing:5px;
  color:var(--fg);
  margin-left:10px;
  padding:4px 12px;
  background:rgba(244,241,234,.08);
  border:1px solid var(--line-strong);
}
.footer-cred-right{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:9px;
  letter-spacing:3px;
  color:var(--fg-dim);
}
.footer-cred-right span:first-child,
.footer-cred-right span:last-child{
  color:var(--warm);
  font-size:14px;
}

/* ==========================================================
   GRUPOS
   ========================================================== */
.grupos{padding:140px 60px;position:relative}

.grupos-intro{
  max-width:700px;
  margin:0 auto 60px;
  text-align:center;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(15px,2vw,18px);
  line-height:1.6;
  color:var(--fg-dim);
}

.grupos-carousel-wrap{
  display:flex;
  align-items:center;
  gap:20px;
  max-width:540px;
  margin:0 auto;
}

.grupos-viewport{
  flex:1;
  overflow:hidden;
}

.grupos-track{
  display:flex;
  transition:transform .6s cubic-bezier(.7,0,.3,1);
  will-change:transform;
  touch-action:pan-y;
}

.grupo-card{
  flex:0 0 100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:30px;
}

.grupo-frame{
  position:relative;
  width:min(100%,320px);
  aspect-ratio:1;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);
  overflow:hidden;
  box-shadow:0 0 60px rgba(244,241,234,.06),0 0 120px rgba(232,217,184,.04);
  transition:box-shadow .4s ease;
}
.grupo-frame:hover{
  box-shadow:0 0 80px rgba(244,241,234,.14),0 0 140px rgba(232,217,184,.08);
}

.grupo-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:contrast(1.02) saturate(.95);
  transition:transform .6s ease;
}
.grupo-frame:hover .grupo-img{transform:scale(1.04)}

.grupo-frame.grupo-no-img .grupo-img{display:none}
.grupo-frame.grupo-no-img .grupo-img-fallback{display:flex}

.grupo-img-fallback{
  display:none;
  position:absolute;
  inset:0;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-weight:900;
  font-size:80px;
  letter-spacing:4px;
  color:rgba(244,241,234,.2);
  background:radial-gradient(circle at 40% 40%,#1c1c1c 0%,#050505 70%);
}

.grupo-scan{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(244,241,234,.07) 50%,transparent 60%);
  animation:scan 5s linear infinite;
  pointer-events:none;
  will-change:transform;
}

.grupo-corner{
  position:absolute;
  width:18px;
  height:18px;
  border:1px solid var(--fg);
  z-index:3;
  pointer-events:none;
}
.grupo-corner.tl{top:8px;left:8px;border-right:none;border-bottom:none}
.grupo-corner.tr{top:8px;right:8px;border-left:none;border-bottom:none}
.grupo-corner.bl{bottom:8px;left:8px;border-right:none;border-top:none}
.grupo-corner.br{bottom:8px;right:8px;border-left:none;border-top:none}

.grupo-role{
  position:absolute;
  top:12px;
  right:12px;
  font-size:8px;
  letter-spacing:3px;
  padding:4px 10px;
  border:1px solid var(--line-strong);
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:var(--fg);
  z-index:4;
}
.grupo-role.adm{
  color:var(--warm);
  border-color:var(--warm);
  background:rgba(232,217,184,.1);
}

.grupo-meta{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
  text-align:center;
}

.grupo-name{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(22px,4vw,36px);
  letter-spacing:6px;
  color:var(--fg);
}

.grupos-foot{
  display:flex;
  justify-content:center;
  margin-top:32px;
}

.grupos-dots{
  display:flex;
  gap:6px;
}

/* ==========================================================
   REVEAL
   ========================================================== */
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity .9s cubic-bezier(.5,0,.2,1), transform .9s cubic-bezier(.5,0,.2,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ==========================================================
   RESPONSIVE — TABLET WIDE (1100px)
   ========================================================== */
@media (max-width:1100px){
  .hero-marker{display:none}
  .side-left,.side-right{display:none}
  .topbar-center{display:none}
  .topbar{padding:18px 24px}
  .ghost-text{font-size:clamp(100px,16vw,200px)}
  .hero-inner{gap:50px}
  .profile-stage{width:min(400px,44vw)}
  .skill-row{grid-template-columns:200px 1fr 50px;gap:20px}
}

/* ==========================================================
   RESPONSIVE — TABLET LANDSCAPE (900px)
   ========================================================== */
@media (max-width:900px){
  .hero-inner{gap:36px}
  .hero-bio{font-size:clamp(17px,2.4vw,20px)}
  .profile-stage{width:min(340px,43vw)}
  .profile-stats{
    padding:10px 16px;
    gap:12px;
  }
  .ps-num{font-size:18px}
  .ps-label{font-size:7px;letter-spacing:2px}
  .skill-row{grid-template-columns:160px 1fr 48px;gap:16px}
  .skill-name{font-size:14px;letter-spacing:3px}
  .friend-code-section{padding:100px 40px}
  .dossier{padding:100px 40px}
  .dossier-grid{grid-template-columns:1fr 1fr}
  .dossier-card{min-height:200px;padding:28px 22px}
  .weapons{padding:100px 40px}
  .gallery{padding:100px 40px}
  .grupos{padding:100px 40px}
  .ledger{padding:100px 40px}
  .quote-section{padding:100px 40px}
  .footer{padding:60px 40px 40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px}
}

/* ==========================================================
   RESPONSIVE — MOBILE (780px)
   ========================================================== */
@media (max-width:780px){
  .loader-img-wrap{
    width:120px;
    height:120px;
    margin-bottom:28px
  }
  .loader-img-ring{
    inset:-8px;
    box-shadow:0 0 15px rgba(244,241,234,.15)
  }
  .loader-img-orbit{
    inset:-18px;
  }
  .loader-img-orbit::before{
    width:6px;
    height:6px;
    top:-3px;
    box-shadow:0 0 10px var(--warm)
  }

  .hero{padding:100px 20px 80px}
  .hero-inner{
    grid-template-columns:1fr;
    gap:60px;
    text-align:left;
  }
  .hero-right{order:-1}
  .hero-bio{font-size:17px;max-width:none}
  .hero-cta-row{gap:12px;width:100%}
  .btn-ghost{padding:13px 22px;font-size:9px;letter-spacing:3px;flex:1;justify-content:center;min-width:130px}
  .hero-coords{padding-left:20px;padding-top:0}
  .hero-name{margin-bottom:24px}
  .ghost-text{display:none}

  .topbar{padding:14px 16px;gap:8px}
  .brand{font-size:11px;letter-spacing:3px;gap:6px}
  .brand-mark{font-size:14px}
  .topbar-meta{font-size:9px;letter-spacing:2px}

  .profile-stage{width:min(300px,80vw)}
  .profile-stats{
    bottom:-44px;
    padding:10px 12px;
    gap:8px;
  }
  .ps-num{font-size:17px}
  .ps-item{min-width:44px}
  .ps-label{font-size:7px;letter-spacing:2px}
  .ps-divider{height:18px}
  .profile-tape{font-size:8px;letter-spacing:2px;padding:0 10px;height:18px}

  .section-rule{margin-bottom:40px;gap:14px;padding:0 4px}
  .section-num{font-size:12px;letter-spacing:2px}
  .section-title{font-size:24px;letter-spacing:4px}

  .friend-code-section{padding:80px 20px}
  .fcs-desc{font-size:15px}
  .dossier{padding:80px 20px}
  .dossier-grid{grid-template-columns:1fr 1fr}
  .dossier-card{padding:24px 18px;min-height:180px}
  .dossier-card-body .big{font-size:24px}
  .dossier-card-body .small{font-size:12px}
  .dossier-card-title{font-size:9px;letter-spacing:3px;margin-bottom:10px}

  .weapons{padding:80px 20px}
  .skill-list{gap:0}
  .skill-row{
    grid-template-columns:1fr 50px;
    grid-template-rows:auto auto;
    gap:8px 12px;
    padding:18px 0;
  }
  .skill-name{
    grid-column:1/3;
    grid-row:1;
    font-size:13px;
    letter-spacing:3px;
  }
  .skill-track{
    grid-column:1;
    grid-row:2;
  }
  .skill-pct{
    grid-column:2;
    grid-row:2;
    font-size:14px;
  }

  .gallery{padding:80px 20px}
  .gallery-intro{margin-bottom:40px}
  .grupos{padding:80px 20px}
  .grupos-intro{margin-bottom:40px}
  .grupos-carousel-wrap{gap:8px}
  .grupo-name{letter-spacing:4px}
  .carousel-stage{gap:8px}
  .carousel-arrow{width:38px;height:38px;flex-shrink:0}
  .carousel-arrow svg{width:18px;height:18px}
  .carousel-viewport{min-height:200px}
  .carousel-viewport::before,
  .carousel-viewport::after{width:14px;height:14px;top:6px}
  .carousel-viewport::before{left:6px}
  .carousel-viewport::after{right:6px}
  .carousel-slide-label{font-size:9px;bottom:10px;left:12px}
  .carousel-foot{margin-top:18px;gap:14px;justify-content:center}
  .carousel-counter{font-size:14px}
  #carouselTotal{font-size:12px}
  .carousel-dots{order:3;width:100%;max-width:none}
  .carousel-dot{width:18px}
  .carousel-dot.active{width:30px}

  .lightbox{padding:50px 16px}
  .lightbox img{max-height:calc(100vh - 140px)}
  .lightbox-arrow{width:42px;height:42px}
  .lightbox-prev{left:8px}
  .lightbox-next{right:8px}
  .lightbox-close{top:14px;right:14px;width:38px;height:38px}

  .quote-section{padding:80px 20px}
  .quote-mark{font-size:80px}

  .ledger{padding:80px 20px}
  .ledger-row{
    grid-template-columns:60px 1fr;
    grid-template-rows:auto auto;
    gap:6px 12px;
    padding:18px 8px;
  }
  .lr-id{grid-column:1;grid-row:1}
  .lr-name{grid-column:2;grid-row:1;font-size:12px;letter-spacing:2px}
  .lr-date{grid-column:1/3;grid-row:2;font-size:10px}
  .lr-status{grid-column:2;grid-row:2;justify-self:end;font-size:8px;padding:4px 8px}
  .ledger-row:hover{padding-left:14px}

  .footer{padding:60px 20px 30px}
  .footer-art{margin-bottom:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px;padding:20px 0;margin-bottom:20px}
  .footer-bottom{flex-direction:column;text-align:center;gap:16px}
  .footer-cred{display:flex;flex-direction:column;align-items:center;gap:10px}
  .footer-cred-name{margin-left:0}

  .hero-tags{font-size:10px;letter-spacing:3px;gap:10px}
}

/* ==========================================================
   RESPONSIVE — SMALL MOBILE (420px)
   ========================================================== */
@media (max-width:420px){
  .hero{padding:90px 16px 70px}
  .hero-name{letter-spacing:-2px}
  .hero-cta-row .btn-ghost{padding:11px 16px;font-size:8px;letter-spacing:2px}
  .profile-stage{width:min(280px,86vw)}
  .profile-stats{gap:6px;padding:8px 10px}
  .ps-num{font-size:15px}
  .ps-item{min-width:38px}
  .dossier-grid{grid-template-columns:1fr}
  .footer-art{font-size:48px;letter-spacing:3px}
  .footer-grid{grid-template-columns:1fr}
  .loader-img-wrap{width:100px;height:100px;margin-bottom:24px}
  .loader-img-ring{inset:-6px}
  .loader-img-orbit{inset:-14px}
  .loader-img-orbit::before{width:5px;height:5px;top:-2px}
  .profile-tape-top{top:18px}
  .profile-tape-bottom{bottom:18px}
}

/* ==========================================================
   RESPONSIVE — LANDSCAPE MOBILE
   ========================================================== */
@media (max-height:500px) and (orientation:landscape){
  .hero{padding:70px 40px 40px;min-height:auto}
  .hero-inner{gap:30px;align-items:flex-start}
  .profile-stage{width:min(220px,35vw)}
  .profile-stats{bottom:-38px;padding:8px 10px;gap:8px}
  .ps-num{font-size:14px}
  .loader-img-wrap{width:90px;height:90px;margin-bottom:20px}
}

/* ==========================================================
   REDUCED MOTION
   ========================================================== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
  }
  html{scroll-behavior:auto}
}


/* ==========================================================
   CARD TASK · SWIPE CARD (AMONG US)
   ========================================================== */
#cardTask{
  position:fixed;inset:0;z-index:9998;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.86);
  transition:opacity .8s,visibility .8s;
}
#cardTask.hidden{opacity:0;visibility:hidden;pointer-events:none}

.ct-wrap{
  position:relative;
  width:100%;max-width:330px;
  display:flex;flex-direction:column;
  user-select:none;
  padding-bottom:30px;
}

/* ── MACHINE ─────────────────────────────────── */
.ct-machine{ position:relative; }
.ct-machine-body{
  background:linear-gradient(180deg,#a2a4a6 0%,#8c8e90 55%,#808284 100%);
  border:3px solid #5a5c5e;
  border-bottom:none;
  border-radius:10px 10px 0 0;
  padding:12px 14px 14px;
  overflow:visible;
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.32),
    inset 2px 0 0 rgba(255,255,255,.12),
    inset -2px 0 0 rgba(0,0,0,.12),
    0 2px 0 #505254;
}
.ct-machine-edge{
  height:6px;
  background:linear-gradient(180deg,#4e5052,#3e4042);
  border:3px solid #3a3c3e;border-top:none;
  border-radius:0 0 4px 4px;
}

/* LCD */
.ct-lcd-box{
  background:#0c1e0a;
  border:2px solid #060e06;
  border-radius:4px;
  padding:6px 10px 7px;
  margin-bottom:12px;
  box-shadow:inset 0 3px 10px rgba(0,0,0,.9),0 1px 0 rgba(255,255,255,.1);
}
.ct-lcd{
  font-family:'IBM Plex Mono',monospace;
  font-size:15px;font-weight:500;
  letter-spacing:2.5px;
  color:#00e04a;
  text-shadow:0 0 8px rgba(0,220,70,.8),0 0 18px rgba(0,220,70,.35);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* Machine mid row */
.ct-machine-mid{
  display:flex;align-items:center;gap:10px;
}

/* Slot housing = card track */
.ct-slot-housing{
  flex:1;
  background:#1c1c1c;
  border:2px solid #0a0a0a;
  border-radius:4px;
  height:66px;
  position:relative;
  overflow:visible;
  box-shadow:inset 0 4px 14px rgba(0,0,0,.95);
  cursor:grab;
}
.ct-slot-housing:active{cursor:grabbing}

/* Idle arrow (disappears once card is inserted) */
.ct-slot-idle{
  position:absolute;
  left:12px;top:50%;transform:translateY(-50%);
  display:flex;align-items:center;gap:5px;
  pointer-events:none;
  transition:opacity .3s;
}
#cardTask.ct-card-inserted .ct-slot-idle{ opacity:0; }
.ct-sl{
  display:block;height:3px;border-radius:2px;
  background:rgba(255,255,255,.22);
}
.ct-sl:nth-child(1){width:22px;opacity:.7}
.ct-sl:nth-child(2){width:16px;opacity:.45}
.ct-sl:nth-child(3){width:11px;opacity:.25}
.ct-slot-arrow{
  color:rgba(255,255,255,.4);font-size:15px;
  animation:ctArrow 1.1s ease-in-out infinite;
}
@keyframes ctArrow{
  0%,100%{opacity:.4;transform:translateX(0)}
  50%{opacity:.85;transform:translateX(4px)}
}

/* Indicators */
.ct-indicators{
  display:flex;flex-direction:column;gap:7px;flex-shrink:0;
  align-self:center;
}
.ct-dot{
  width:20px;height:20px;border-radius:50%;
  border:2px solid rgba(0,0,0,.45);
  box-shadow:inset 0 2px 4px rgba(0,0,0,.5),0 1px 0 rgba(255,255,255,.15);
}
.ct-dot-red{
  background:radial-gradient(circle at 38% 32%,#f05050,#8a0000);
  box-shadow:inset 0 2px 4px rgba(0,0,0,.5),0 0 5px rgba(200,30,30,.6);
}
.ct-dot-green{
  background:radial-gradient(circle at 38% 32%,#2a5a2a,#0e2a0e);
}
.ct-dot-green.on{
  background:radial-gradient(circle at 38% 32%,#88ff66,#22bb22);
  box-shadow:inset 0 2px 4px rgba(0,0,0,.3),0 0 14px rgba(80,255,80,.9);
}
.ct-dot-red.blink{ animation:ctRedBlink .25s ease-in-out 3; }
@keyframes ctRedBlink{
  0%,100%{background:radial-gradient(circle at 38% 32%,#f05050,#8a0000)}
  50%{background:radial-gradient(circle at 38% 32%,#ff8888,#cc2222);box-shadow:0 0 16px rgba(255,60,60,1)}
}

/* Sensor zone (invisible, for detection) */
.ct-sensor-zone{
  position:absolute;top:0;bottom:0;
  width:44px;pointer-events:none;
}

/* Card */
.ct-card{
  position:absolute;top:50%;
  transform:translateY(-50%);
  width:92px;height:60px;
  background:linear-gradient(150deg,#d4a868 0%,#c09040 55%,#b07830 100%);
  border:2px solid #7a5018;
  border-radius:5px;
  overflow:hidden;
  cursor:grab;touch-action:none;
  will-change:left;
  box-shadow:0 3px 10px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.25);
  z-index:10;
}
.ct-card:active{cursor:grabbing}
.ct-card-face{
  display:flex;align-items:center;
  padding:6px 7px;gap:5px;height:50px;
}
.ct-card-chip{
  width:16px;height:12px;flex-shrink:0;
  background:linear-gradient(145deg,#c8a840,#f0d058,#b89030);
  border-radius:2px;border:1px solid rgba(0,0,0,.35);
  box-shadow:inset 0 1px 2px rgba(255,255,255,.2);
}
.ct-card-crew{flex-shrink:0;line-height:0}
.ct-card-meta{flex:1;min-width:0}
.ct-card-name{
  font-family:'IBM Plex Mono',monospace;
  font-size:6.5px;letter-spacing:1px;
  color:rgba(10,10,10,.75);font-weight:600;
  white-space:nowrap;overflow:hidden;
}
.ct-card-id{
  font-family:'IBM Plex Mono',monospace;
  font-size:6px;letter-spacing:1px;
  color:rgba(10,10,10,.5);margin-top:2px;
}
.ct-card-mag{
  height:10px;
  background:repeating-linear-gradient(90deg,#111 0,#111 2px,#1c1c1c 2px,#1c1c1c 4px);
  border-top:1px solid rgba(0,0,0,.5);
}

/* Card state classes */
#cardTask.ct-active .ct-card{
  box-shadow:0 3px 14px rgba(255,220,50,.55),inset 0 1px 0 rgba(255,255,255,.25);
}
#cardTask.ct-success .ct-card{
  box-shadow:0 3px 18px rgba(60,255,90,.55),inset 0 1px 0 rgba(255,255,255,.25);
}
#cardTask.ct-error .ct-card{ animation:ctShake .36s ease; }
@keyframes ctShake{
  0%,100%{transform:translateY(-50%) translateX(0)}
  20%{transform:translateY(-50%) translateX(-7px)}
  45%{transform:translateY(-50%) translateX(7px)}
  65%{transform:translateY(-50%) translateX(-5px)}
  82%{transform:translateY(-50%) translateX(4px)}
}

/* ── WALLET ──────────────────────────────────── */
.ct-wallet-area{
  background:linear-gradient(180deg,#5c5e60 0%,#4c4e50 100%);
  border:3px solid #4a4c4e;border-top:none;
  border-radius:0 0 10px 10px;
  padding:10px 12px 14px;
}
.ct-wallet{
  display:flex;height:118px;
  border-radius:8px;
  border:3px solid #3a1c06;
  overflow:hidden;
  box-shadow:0 4px 18px rgba(0,0,0,.65),inset 0 2px 0 rgba(255,255,255,.12);
  background:#8b4010;
}
.ct-wallet::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 55%);
  pointer-events:none;border-radius:6px;
}
.ct-wallet-left{
  flex:1;
  background:linear-gradient(135deg,#7a3808,#5a2806);
  padding:6px 8px 0;
  display:flex;flex-direction:column;align-items:center;
  overflow:hidden;
}
.ct-wallet-seam{
  width:4px;
  background:linear-gradient(90deg,#2e1004,#4a1e08);
  flex-shrink:0;
}
.ct-wallet-right{
  flex:1;
  background:linear-gradient(135deg,#8b4010,#6a3008);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:8px;gap:5px;
  cursor:pointer;
  transition:filter .2s;
}
.ct-wallet-right:hover{ filter:brightness(1.12); }
#cardTask.ct-card-inserted .ct-wallet-right{
  cursor:default;filter:brightness(.7);
}

/* Wallet papers */
.ct-w-paper{
  width:72%;height:24px;
  background:linear-gradient(180deg,#f5f0e0,#ede0c4);
  border-radius:2px 2px 0 0;border:1px solid rgba(0,0,0,.18);
  transform:rotate(-3deg) translateY(-6px);
  box-shadow:0 3px 6px rgba(0,0,0,.35);flex-shrink:0;
}
.ct-wp2{
  transform:rotate(4deg) translateY(-14px) translateX(5px);
  background:linear-gradient(180deg,#f0e8d0,#e8d8b4);
  height:20px;width:64%;
}
.ct-wp3{
  transform:rotate(-1.5deg) translateY(-22px) translateX(-3px);
  background:linear-gradient(180deg,#eae2cc,#ddd0a8);
  height:18px;width:58%;
}

/* Wallet card slot */
.ct-wallet-card-slot{
  width:62px;height:86px;
  background:linear-gradient(160deg,#1a4a2a,#0a2810);
  border:2px solid rgba(0,0,0,.45);border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 2px 10px rgba(0,0,0,.7);
  overflow:hidden;
  animation:ctCardBob 2s ease-in-out infinite;
}
#cardTask.ct-card-inserted .ct-wallet-card-slot{ animation:none; }
@keyframes ctCardBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-5px)}
}

/* Tap hint */
.ct-tap-hint{
  font-family:'IBM Plex Mono',monospace;
  font-size:8px;letter-spacing:1px;
  color:rgba(255,255,255,.45);
  text-align:center;
  animation:ctHintBlink 2s ease-in-out infinite;
}
#cardTask.ct-card-inserted .ct-tap-hint{ opacity:0; }
@keyframes ctHintBlink{
  0%,100%{opacity:.45} 50%{opacity:.85}
}

/* Skip */
.ct-skip{
  position:absolute;bottom:-22px;right:0;
  background:none;border:none;
  color:rgba(255,255,255,.2);
  font-family:'IBM Plex Mono',monospace;
  font-size:9px;letter-spacing:2px;
  cursor:pointer;padding:4px 2px;
  transition:color .2s;
}
.ct-skip:hover{color:rgba(255,255,255,.5)}
.ct-skip.hidden{display:none}

@media(max-width:380px){
  .ct-lcd{font-size:12px;letter-spacing:1.5px}
  .ct-machine-body{padding:10px 10px 12px}
  .ct-wallet-area{padding:8px 10px 12px}
}
