/* =========================================================
   Fantasy Sumo — Tema japonés (sumi / washi / hinomaru)
   ========================================================= */

:root{
  --sumi:#1c1a17;        /* tinta */
  --sumi-soft:#33302b;
  --washi:#f4ece1;       /* papel */
  --washi-deep:#e9ddca;
  --hinomaru:#bc002d;    /* rojo bandera */
  --hinomaru-dark:#8c0021;
  --gold:#c9a227;        /* oro */
  --gold-soft:#e3c869;
  --ink-muted:#6b6358;
  --line:#d8cbb4;
  --shadow:0 10px 30px rgba(28,26,23,.12);
  --radius:14px;
  --maxw:1180px;
  --serif:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",Georgia,"Times New Roman",serif;
  --sans:"Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",-apple-system,system-ui,"Segoe UI",sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--sumi);
  background:
    radial-gradient(circle at 12% -10%, rgba(201,162,39,.10), transparent 40%),
    radial-gradient(circle at 100% 0%, rgba(188,0,45,.07), transparent 35%),
    var(--washi);
  background-attachment:fixed;
  line-height:1.6;
  min-height:100vh;
}
/* textura washi sutil */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:
    repeating-linear-gradient(0deg, rgba(28,26,23,.015) 0 2px, transparent 2px 4px),
    repeating-linear-gradient(90deg, rgba(28,26,23,.015) 0 2px, transparent 2px 4px);
}
#app, header, footer{position:relative;z-index:1}

a{color:var(--hinomaru-dark);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:.3px;line-height:1.2}

/* ----------------------- Header ----------------------- */
header.site{
  background:linear-gradient(180deg, var(--sumi), var(--sumi-soft));
  color:var(--washi);
  border-bottom:4px solid var(--hinomaru);
  box-shadow:var(--shadow);
}
.nav{
  max-width:var(--maxw);margin:0 auto;padding:14px 20px;
  display:flex;align-items:center;gap:22px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:14px;cursor:pointer}
.brand .mon{
  width:46px;height:46px;border-radius:50%;
  background:radial-gradient(circle at 50% 42%, var(--hinomaru) 0 58%, var(--hinomaru-dark) 60% 100%);
  display:grid;place-items:center;color:#fff;font-family:var(--serif);font-size:24px;
  box-shadow:0 0 0 3px rgba(244,236,225,.15), inset 0 -3px 8px rgba(0,0,0,.25);
}
.brand .title{display:flex;flex-direction:column;line-height:1}
.brand .title b{font-family:var(--serif);font-size:1.25rem;letter-spacing:1px}
.brand .title span{font-size:.72rem;color:var(--gold-soft);letter-spacing:3px;text-transform:uppercase}
.brand .jp{font-family:var(--serif);color:var(--gold-soft);font-size:1.1rem;margin-left:2px}

nav.menu{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}
nav.menu a{
  color:var(--washi);padding:8px 14px;border-radius:999px;font-size:.92rem;
  opacity:.85;transition:.18s;
}
nav.menu a:hover{background:rgba(244,236,225,.12);opacity:1;text-decoration:none}
nav.menu a.active{background:var(--hinomaru);opacity:1;box-shadow:inset 0 -2px 6px rgba(0,0,0,.3)}

.lang{display:flex;border:1px solid rgba(244,236,225,.3);border-radius:999px;overflow:hidden}
.lang button{
  background:transparent;color:var(--washi);border:0;padding:6px 12px;cursor:pointer;
  font-size:.8rem;font-weight:600;letter-spacing:1px;transition:.15s
}
.lang button.active{background:var(--gold);color:var(--sumi)}

/* ----------------------- Layout ----------------------- */
main{max-width:var(--maxw);margin:0 auto;padding:30px 20px 60px}
.section-title{
  display:flex;align-items:center;gap:14px;margin:6px 0 22px
}
.section-title .kanji{font-family:var(--serif);color:var(--hinomaru);font-size:1.8rem}
.section-title h2{margin:0;font-size:1.6rem}
.section-title .rule{flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent)}

/* ----------------------- Hero ----------------------- */
.hero{
  position:relative;overflow:hidden;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--sumi),var(--sumi-soft));
  color:var(--washi);padding:48px 40px;margin-bottom:34px;box-shadow:var(--shadow);
}
.hero::after{
  content:"力";position:absolute;right:-10px;bottom:-40px;font-family:var(--serif);
  font-size:18rem;color:rgba(188,0,45,.16);line-height:1;pointer-events:none
}
.hero .sun{
  position:absolute;top:-60px;left:-60px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle, rgba(188,0,45,.35), transparent 70%)
}
.hero h1{font-size:2.6rem;margin:0 0 10px;max-width:680px}
.hero p{max-width:620px;opacity:.9;font-size:1.05rem}
.hero .cta{margin-top:22px;display:flex;gap:12px;flex-wrap:wrap}

/* ----------------------- Buttons ----------------------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:0;
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  padding:11px 20px;border-radius:999px;transition:.18s;text-decoration:none
}
.btn-primary{background:var(--hinomaru);color:#fff;box-shadow:0 6px 16px rgba(188,0,45,.35)}
.btn-primary:hover{background:var(--hinomaru-dark);text-decoration:none;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--washi);border:1px solid rgba(244,236,225,.4)}
.btn-ghost:hover{background:rgba(244,236,225,.1);text-decoration:none}
.btn-outline{background:#fff;color:var(--sumi);border:1px solid var(--line)}
.btn-outline:hover{border-color:var(--hinomaru);color:var(--hinomaru-dark);text-decoration:none}

/* ----------------------- Cards ----------------------- */
.grid{display:grid;gap:18px}
.grid.cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.grid.three{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}

.card{
  background:#fffdf8;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;transition:.18s
}
.card.link{cursor:pointer}
.card.link:hover{transform:translateY(-3px);border-color:var(--gold)}

.rikishi-card{display:flex;flex-direction:column}
.rikishi-card .avatar{
  height:120px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--washi-deep),#fff);
  border-bottom:1px solid var(--line);position:relative
}
.rikishi-card .body{padding:14px 16px}
.rikishi-card .shikona{font-family:var(--serif);font-size:1.15rem;margin:0 0 2px}
.rikishi-card .jp{color:var(--ink-muted);font-family:var(--serif);font-size:.95rem}
.rikishi-card .rank{
  display:inline-block;margin-top:8px;font-size:.78rem;font-weight:600;
  color:var(--hinomaru-dark);background:rgba(188,0,45,.08);
  padding:3px 10px;border-radius:999px
}
.meta-row{display:flex;gap:14px;flex-wrap:wrap;color:var(--ink-muted);font-size:.82rem;margin-top:10px}

/* mon avatar (placeholder de foto) */
.mon-avatar{
  width:84px;height:84px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--serif);font-size:1.7rem;color:#fff;font-weight:600;
  box-shadow:inset 0 -4px 10px rgba(0,0,0,.25), 0 4px 10px rgba(0,0,0,.12)
}

/* ----------------------- Ficha rikishi ----------------------- */
.profile-head{
  display:flex;gap:24px;align-items:center;flex-wrap:wrap;
  background:#fffdf8;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);margin-bottom:24px;position:relative;overflow:hidden
}
.profile-head::after{
  content:"";position:absolute;right:0;top:0;bottom:0;width:8px;background:var(--hinomaru)
}
.profile-head .mon-avatar{width:110px;height:110px;font-size:2.2rem}
.profile-head h1{margin:0;font-size:2rem}
.profile-head .jp-name{font-family:var(--serif);color:var(--ink-muted);font-size:1.2rem}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.tag{font-size:.78rem;background:var(--washi-deep);border:1px solid var(--line);
  padding:4px 11px;border-radius:999px;color:var(--sumi-soft)}
.tag.gold{background:rgba(201,162,39,.16);border-color:var(--gold);color:#7a5e00}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px;margin-bottom:24px}
.stat{
  background:#fffdf8;border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center
}
.stat .num{font-family:var(--serif);font-size:1.9rem;color:var(--hinomaru-dark);line-height:1}
.stat .lbl{font-size:.78rem;color:var(--ink-muted);margin-top:6px;text-transform:uppercase;letter-spacing:.5px}

.panel{
  background:#fffdf8;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);margin-bottom:22px
}
.panel h3{margin:0 0 14px;display:flex;align-items:center;gap:10px}
.panel h3 .kanji{color:var(--hinomaru);font-family:var(--serif)}
.chart-box{position:relative;height:300px}

/* ----------------------- Controls ----------------------- */
.controls{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px;align-items:center}
.search{
  flex:1;min-width:220px;display:flex;align-items:center;gap:10px;
  background:#fffdf8;border:1px solid var(--line);border-radius:999px;padding:10px 18px
}
.search input{border:0;background:transparent;outline:none;flex:1;font-size:1rem;font-family:var(--sans)}
select.filter{
  border:1px solid var(--line);background:#fffdf8;border-radius:999px;
  padding:10px 16px;font-family:var(--sans);font-size:.92rem;cursor:pointer;color:var(--sumi)
}

/* ----------------------- Tables ----------------------- */
table.data{width:100%;border-collapse:collapse;font-size:.92rem}
table.data th,table.data td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line)}
table.data th{font-family:var(--serif);color:var(--ink-muted);font-weight:600}
table.data tr:hover td{background:rgba(201,162,39,.06)}
.win{color:#2e7d32;font-weight:700}
.loss{color:var(--hinomaru-dark);font-weight:700}

/* ----------------------- States ----------------------- */
.loader{display:flex;flex-direction:column;align-items:center;gap:14px;padding:70px 0;color:var(--ink-muted)}
.spinner{
  width:46px;height:46px;border-radius:50%;
  border:4px solid var(--washi-deep);border-top-color:var(--hinomaru);
  animation:spin .9s linear infinite
}
@keyframes spin{to{transform:rotate(360deg)}}
.error{
  background:rgba(188,0,45,.06);border:1px solid var(--hinomaru);color:var(--hinomaru-dark);
  border-radius:12px;padding:18px 20px;margin:10px 0
}
.empty{text-align:center;color:var(--ink-muted);padding:50px 0}

/* glosario tooltip */
.term{border-bottom:1px dotted var(--gold);cursor:help}

/* ----------------------- Footer ----------------------- */
footer.site{
  background:var(--sumi);color:var(--washi);margin-top:40px;
  border-top:4px solid var(--hinomaru)
}
footer.site .inner{max-width:var(--maxw);margin:0 auto;padding:26px 20px;
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.85rem;opacity:.85}
footer.site a{color:var(--gold-soft)}

.fade-in{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

@media (max-width:640px){
  .hero{padding:34px 22px}
  .hero h1{font-size:2rem}
  nav.menu{order:3;width:100%}
  nav.menu a{flex:1;text-align:center}
}

/* ----------------------- Fotos y atribución ----------------------- */
.photo-box{
  width:120px;height:150px;border-radius:12px;overflow:hidden;flex:0 0 auto;
  border:1px solid var(--line);background:linear-gradient(135deg,var(--washi-deep),#fff);
  display:grid;place-items:center;position:relative
}
.photo-box .mon-avatar{width:84px;height:84px;font-size:32px}
.photo-box img{width:100%;height:100%;object-fit:cover;display:block}
.attrib{font-size:.68rem;color:var(--ink-muted);margin-top:6px;line-height:1.4}
.attrib a{color:var(--ink-muted);text-decoration:underline}
.attrib a:hover{color:var(--hinomaru-dark)}

.rikishi-card .avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.rikishi-card .avatar{overflow:hidden}

.venue-banner{
  position:relative;height:200px;border-radius:var(--radius);overflow:hidden;
  margin-bottom:22px;box-shadow:var(--shadow);background:var(--sumi)
}
.venue-banner img{width:100%;height:100%;object-fit:cover;opacity:.92}
.venue-banner .cap{
  position:absolute;left:0;right:0;bottom:0;padding:8px 14px;color:#fff;
  background:linear-gradient(0deg, rgba(0,0,0,.65), transparent);font-size:.7rem
}
.venue-banner .cap a{color:#fff;text-decoration:underline}

/* ----------------------- Cara a cara ----------------------- */
.h2h-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.h2h-bar{display:flex;height:30px;border-radius:8px;overflow:hidden;border:1px solid var(--line);margin:14px 0}
.h2h-bar .me{background:var(--hinomaru)}
.h2h-bar .op{background:var(--sumi-soft)}
.h2h-bar span{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;min-width:32px}
.h2h-score{display:flex;justify-content:space-between;font-family:var(--serif);font-size:1.05rem;margin-top:4px}

/* ----------------------- Kimarite ----------------------- */
.kimarite-card{background:#fffdf8;border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:var(--shadow)}
.kimarite-card .name{font-family:var(--serif);font-size:1.15rem;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.kimarite-card .jp{color:var(--hinomaru-dark);font-size:.95rem}
.kimarite-card .count{font-size:.72rem;color:var(--ink-muted);background:var(--washi-deep);padding:2px 9px;border-radius:999px;white-space:nowrap}
.kimarite-card .desc{color:var(--sumi-soft);font-size:.88rem;margin-top:8px}
.kimarite-card .last{font-size:.72rem;color:var(--ink-muted);margin-top:8px}

/* viñeta sumi-e en la tarjeta de kimarite */
.kimarite-card .vignette{
  background:#f4ece1;border:1px solid var(--line);border-radius:10px;
  margin-bottom:12px;padding:4px;overflow:hidden
}
.kimarite-card .vignette svg{display:block;width:100%;height:auto}
