/* ===== Siracusa Filmlook (Arknights-inspired) ===== */

/* Reset */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
:root{
  --heading-font:'Cinzel', serif;
  --body-font:Inter, system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial;

  /* Palette: cold blue + red accent */
  --bg:#08090d;
  --panel:#0d0f15;
  --panel-2:#121520;
  --text:#dcdde1;
  --muted:#9aa3b2;
  --blue:#3a6aff;      /* cold blue */
  --blue-2:#2a3d66;
  --red:#e63946;       /* arknights red */
  --ring: 0 0 0 2px color-mix(in srgb, var(--blue) 45%, transparent);
}

/* Base */
body{
  font:500 16px/1.7 var(--body-font);
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* Nav */
.nav{
  position:fixed; top:0; left:0; right:0; height:66px;
  display:flex; align-items:center; gap:.9rem;
  background:rgba(6,8,12,.7); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:0 1rem; z-index:10;
}
.brand .crest-img{height:26px;width:auto;object-fit:contain;filter:drop-shadow(0 0 2px rgba(0,0,0,.6));}
.nav .brand{display:flex; align-items:center; gap:.5rem; padding:.2rem .6rem; border-right:1px solid rgba(255,255,255,.08)}
.nav .brand .name{font-family:var(--heading-font);font-weight:800; letter-spacing:.14em; font-size:.92rem; color:var(--blue)}
.nav .brand .sep{opacity:.6}
.nav .brand .unit{letter-spacing:.12em; font-size:.9rem}
.nav .fill{flex:1}
.nav a{ text-transform:uppercase; letter-spacing:.1em; font-size:.82rem; color:var(--text); opacity:.9; padding:.4rem .5rem }
.nav a:hover{opacity:1}

/* Hero grid */
.hero{
  position:relative; min-height:88vh;
  display:grid; grid-template-columns: 1.05fr .95fr; gap:2rem;
  align-items:center; padding:7rem 1.2rem 2rem; max-width:1200px; margin:0 auto;
}
.hero-head h1{
  font-family:var(--heading-font);
  font-weight:900; font-size:clamp(2.6rem,5.2vw,4rem); letter-spacing:.04em; text-transform:uppercase;
}
.hero-head h1 .tiny{display:block; font-size:.55em; letter-spacing:.16em; color:var(--muted); margin-bottom:.2rem}
.hero-head .crest-hero{height:52px;width:auto;object-fit:contain;margin-left:.6rem;vertical-align:middle; filter:drop-shadow(0 0 4px rgba(0,0,0,.65));}
.lead{margin:.7rem 0 1.1rem; color:#e9edf3; opacity:.95}

.avatar{
  width:clamp(240px, 30vw, 420px);
  height:auto;
  border-radius:12px;
  box-shadow:0 8px 22px rgba(0,0,0,.45);
  object-fit:cover;
  display:block;
  opacity:0;
  transform:translateY(6px);
}
.avatar.is-visible{
  opacity:1;
  transform:translateY(0);
  transition:opacity .35s ease, transform .35s ease;
}

.ribbons{display:flex; gap:.5rem; flex-wrap:wrap; margin:.5rem 0 1.3rem}
.ribbon{
  font-size:.8rem; padding:.35rem .6rem;
  border:1px solid rgba(255,255,255,.12); border-radius:8px;
  background:linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%);
}
.ribbon.blue{ border-color: color-mix(in srgb, var(--blue) 60%, transparent); color:#c9d6ff }
.ribbon.red { border-color: color-mix(in srgb, var(--red) 60%, transparent);  color:#ffc9ce }

/* CTA */
.cta{ text-align:center; }
.cta .sub{color:var(--muted)}
.counter{
  font-variant-numeric:tabular-nums;
  font-size:clamp(3rem,6.8vw,5rem); font-weight:900; letter-spacing:.01em;
  text-shadow:0 0 22px rgba(58,106,255,.25);
  position:relative; margin:.2rem 0 .5rem;
}
.counter::after{
  content:""; position:absolute; left:0; bottom:-10px; width:150px; height:2px;
  background:linear-gradient(90deg, var(--blue), transparent);
  opacity:.9;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%);
  color:var(--text); padding:.9rem 1.3rem; border-radius:10px;
  cursor:pointer; transition:transform .05s, box-shadow .2s, border-color .2s;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
}
.btn.primary{ border-color: color-mix(in srgb, var(--red) 60%, transparent); }
.btn.primary:hover{ box-shadow:0 20px 40px rgba(230,57,70,.22); border-color: var(--red); }
.btn:active{ transform:translateY(1px) scale(.99) }
.btn.big{ font-size:1.05rem; padding:1.05rem 1.6rem; border-width:2px; box-shadow:0 18px 36px rgba(0,0,0,.36); margin-top: 1cm; }
.btn.big:hover{ transform:translateY(-1px); }

/* Portrait frame */
.hero-figure{display:flex; justify-content:center}
.frame{
  padding:10px; border-radius:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.2)),
    conic-gradient(from 90deg, rgba(58,106,255,.25), transparent 70%);
  border:1px solid rgba(255,255,255,.1);
  box-shadow: 0 16px 36px rgba(0,0,0,.45);
}
.avatar{
  width:clamp(240px, 30vw, 420px); height:auto; border-radius:12px;
  box-shadow: 0 8px 22px rgba(0,0,0,.45);
}

/* Film overlays */
.film-canvas{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.22; }
.film-scratches{
  position:absolute; inset:-2rem; z-index:1; pointer-events:none; opacity:.18;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 6px),
    repeating-linear-gradient(0deg,  rgba(255,255,255,.02) 0 2px, transparent 2px 10px);
  animation: scratches 10s linear infinite;
  mix-blend-mode:screen;
}
@keyframes scratches{
  from{ transform: translateY(0) }
  to  { transform: translateY(-120px) }
}
.vignette{
  position:absolute; inset:-5vmax; z-index:2; pointer-events:none;
  background:
    radial-gradient(120vmax 85vmax at 50% 12%, transparent 35%, rgba(0,0,0,.6) 100%),
    radial-gradient(60vmax 45vmax at 20% 15%, rgba(230,57,70,.08), transparent 60%),
    radial-gradient(70vmax 40vmax at 80% 20%, rgba(58,106,255,.10), transparent 60%);
}

/* Dust/ground (kept subtle) */
.ground{
  position:fixed; left:0; right:0; bottom:7vh; height:18vh; z-index:-1;
  background:
    linear-gradient(0deg, rgba(0,0,0,.7), transparent 60%),
    repeating-linear-gradient(90deg, rgba(58,106,255,.10) 0 14px, transparent 14px 28px);
  filter: blur(0.3px);
}

/* Runner — slower, bigger, with afterimage trail + speedlines */
#runner-container{ position:fixed; bottom:9vh; left:0; width:100%; height:1px; pointer-events:none; z-index:4; }
.runner{
  position:absolute; top:-50vh; left:-25vw; width:auto;
  height:clamp(300px, 42vh, 560px);
  animation:run var(--run-speed, 2.8s) cubic-bezier(.15,.85,.2,1) forwards;
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.55));
}
.after{
  position:absolute; opacity:.22; filter: blur(1.2px) saturate(105%);
  transform:translateY(var(--lane, 0));
  height:clamp(260px, 34vh, 500px); width:auto; pointer-events:none;
}
@keyframes run { to { transform: translateX(140vw) translateY(0); } }
.speedline{
  position:absolute; top:0; left:-20vw; height:2px; width:18vw;
  background: linear-gradient(90deg, rgba(255,255,255,.0), rgba(58,106,255,.55), rgba(255,255,255,0));
  filter: blur(1px); opacity:.42; pointer-events:none;
  transform: translateY(var(--sy, 0)) skewX(-12deg);
}

/* Panels */
.panel{
  max-width:1200px; margin:1.2rem auto; padding:1.4rem 1.2rem;
  background:linear-gradient(180deg, rgba(16,18,26,.92) 0%, rgba(12,14,22,.92) 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px; box-shadow:0 14px 34px rgba(0,0,0,.28);
  position:relative; overflow:hidden;
}
.panel.ornate::before{
  content:""; position:absolute; left:-26px; top:-26px; width:130px; height:130px;
  transform:rotate(45deg);
  background:conic-gradient(from 0deg, rgba(58,106,255,.28), transparent 70%);
  filter:blur(16px); opacity:.6; pointer-events:none;
}
.panel h2{
  font-family:var(--heading-font);
  margin:0 0 .9rem; font-size:clamp(1.2rem,2.2vw,1.6rem);
  text-transform:uppercase; letter-spacing:.12em; position:relative; display:inline-block; padding-right:.6rem;
}
.panel h2::after{
  content:""; position:absolute; right:-.2rem; bottom:-.35rem; left:0; height:2px;
  background:linear-gradient(90deg, var(--blue), transparent 70%); opacity:.9;
}
.panel p, blockquote, .facts{line-height:1.78;color:var(--text);opacity:.96}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:1.2rem}
.facts{list-style:none}
.facts li{padding:.3rem 0; border-bottom:1px dashed rgba(255,255,255,.08)}
.facts li b{color:#fff}

/* Tabs */
.tabs{display:flex; gap:.6rem; margin:.3rem 0 1rem}
.tab{
  font:600 .9rem var(--body-font); letter-spacing:.05em; text-transform:uppercase;
  padding:.45rem .8rem; border-radius:8px; cursor:pointer;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%); color:var(--text);
  opacity:.85;
}
.tab.active{ opacity:1; border-color: color-mix(in srgb, var(--blue) 60%, transparent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--blue) 30%, transparent) inset; }
.tab-panels{ margin-top:.4rem }
.tab-panel{ display:none }
.tab-panel.active{ display:block }

/* Voice line slider */
.voices{ display:grid; grid-template-columns: auto 1fr auto; align-items:center; gap:.6rem }
.voices button{ border:1px solid rgba(255,255,255,.14); background:transparent; color:var(--text); padding:.4rem .6rem; border-radius:8px; cursor:pointer }
#voice-line{ margin:0; padding:.4rem 1rem; border-left:3px solid var(--blue) }
.attrib{opacity:.7;font-size:.85rem;margin:.3rem 0 .6rem}

/* Hover zeigt Max-Balken + Max-Wert */
#stats:hover .bar i { width: calc(var(--pmax, 1) * 100%) }
#stats:hover .val-base { opacity: 0; transform: translateY(-2px) }
#stats:hover .val-max  { opacity: 1; transform: translateY(0) }

/* Grid & Zeile */
.stats-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:.8rem 1rem; margin-top:.6rem }
.stat-row{ display:flex; align-items:center; gap:.6rem }

/* Labels & Werte */
.stat-name{ width:110px; font-weight:800; letter-spacing:.08em }
.stat-val{ width:84px; font-variant-numeric: tabular-nums; position:relative; height:1.2em }
.stat-val > span{ position:absolute; left:0; top:0; transition:all .25s ease; }
.val-base{ opacity:1 }
.val-max{ opacity:0 }

/* Balken */
.bar{ flex:1; height:12px; border:1px solid rgba(255,255,255,.14); border-radius:999px; position:relative;
  background:linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%); overflow:hidden }
.bar i{ position:absolute; inset:0 auto 0 0; width: calc(var(--p,0) * 100%); border-radius:999px;
  background: linear-gradient(90deg, rgba(58,106,255,.25), rgba(58,106,255,.8));
  box-shadow:0 0 10px rgba(58,106,255,.28) inset; transition: width .45s ease; }

/* Delta (+X) am Ende */
.delta{ width:72px; text-align:right; font-variant-numeric: tabular-nums; opacity:.85 }
.delta.positive{ color:#7ad67a }
.delta.zero{ opacity:.55 }

/* Fix-Werte etwas neutraler */
.stat-row.is-fixed .bar i{ background:linear-gradient(90deg, rgba(120,120,120,.2), rgba(180,180,180,.55)) }


/* Footer & stats */
.foot{ text-align:center; opacity:.7; font-size:1rem; margin:2.4rem 0 1.2rem }
.visit#visit-stats{
  max-width:1200px; margin:1.2rem auto 3rem; padding:.9rem 1.1rem;
  text-align:center; opacity:.9;
  border:1px dashed rgba(255,255,255,.12); border-radius:12px;
  color:var(--muted);
  font-family:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
.visit#visit-stats b{color:var(--blue);font-weight:700}
.noscript{max-width:1200px;margin:1rem auto;padding:1rem;border:1px solid #444;border-radius:8px}

/* Responsive */
@media(max-width:980px){
  .hero{grid-template-columns:1fr; gap:1rem; padding-top:6.6rem}
  .hero-figure{order:-1}
  .avatar{width:clamp(220px, 54vw, 420px)}
  #runner-container{bottom:11vh}
  .grid2{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav{height:60px}
  .nav .brand .name,.nav .brand .sep{display:none}
  .hero{min-height:82vh}
  .runner{height:clamp(260px, 38vh, 520px)}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .runner{animation:none}
  .film-canvas,.film-scratches{display:none}
}

/* Nav mute button */
.mute-btn{
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%);
  color:var(--text);
  padding:.45rem .6rem;
  border-radius:8px;
  cursor:pointer;
  font-size:1rem;
  margin-left:.4rem;
}
.mute-btn:hover{ border-color: color-mix(in srgb, var(--blue) 60%, transparent); }
.mute-btn[aria-pressed="true"]{ opacity:.8; }

.skills-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.2rem;
}
.skill{
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  background: linear-gradient(180deg, var(--panel) 0%, var(--panel-2) 100%);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  padding: 1rem;
}
.skill-gif{
  width: 160px;
  height: auto;
  border-radius: 8px;
  object-fit: cover;
  box-shadow: 0 4px 14px rgba(0,0,0,.4);
}
.skill-info h3{
  margin: 0 0 .4rem;
  font-family: var(--heading-font);
  font-size: 1.1rem;
  letter-spacing: .05em;
}
.skill-info p{
  margin: 0 0 .4rem;
  opacity: .95;
}
.skill-info ul{
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: .9rem;
  opacity: .85;
}
.skill-info li::before{
  content: "• ";
  color: var(--blue);
}
.talents{
  margin-top: 1.4rem;
  padding: 1rem;
  border-top: 1px dashed rgba(255,255,255,.12);
}
.talents h3{
  margin-bottom: .5rem;
  font-family: var(--heading-font);
  font-size: 1.05rem;
}
.talents ul{
  list-style: none;
  padding: 0;
  margin: 0;
}
.talents li{
  margin-bottom: .3rem;
}
