/* UniverKod — tema espacial */
:root{
  --bg:#070914; --bg2:#0e1326; --panel:#121a33; --panel2:#0c1024;
  --line:#243056; --txt:#dfe6ff; --muted:#8895c0; --accent:#5b8cff;
  --accent2:#9b6bff; --ok:#37d39a; --warn:#ffb454; --bad:#ff5d6c;
  --metal:#cdd3df; --crystal:#7fd0ff; --deut:#8affc1;
}
*{box-sizing:border-box}
body{
  margin:0; font-family:"Segoe UI",system-ui,Arial,sans-serif; color:var(--txt);
  background:
    radial-gradient(1200px 700px at 80% -10%, #1b2550 0%, transparent 60%),
    radial-gradient(900px 600px at 0% 110%, #2a1a4d 0%, transparent 55%),
    var(--bg);
  min-height:100vh;
}
a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:underline}
.mono{font-family:"Consolas",monospace}

/* Topbar */
.topbar{
  display:flex; align-items:center; gap:18px; padding:12px 22px;
  background:rgba(8,11,22,.75); border-bottom:1px solid var(--line);
  position:sticky; top:0; backdrop-filter:blur(8px); z-index:10;
}
.brand{font-size:22px; font-weight:800; letter-spacing:.5px; color:#fff}
.brand span{color:var(--accent)}
.topbar nav{display:flex; gap:6px; flex:1}
.topbar nav a{color:var(--muted); padding:7px 12px; border-radius:8px; font-weight:600}
.topbar nav a:hover{background:var(--panel); color:var(--txt); text-decoration:none}
.topbar nav a.on{background:var(--accent); color:#fff}
.userbox{display:flex; align-items:center; gap:12px}
.uname{font-weight:700}
.logout{color:var(--muted)}
.langsel{background:var(--bg2); border:1px solid var(--line); color:var(--txt); padding:6px 8px; border-radius:8px; font-size:13px}

.wrap{max-width:1040px; margin:0 auto; padding:24px 18px 60px}
.foot{text-align:center; color:var(--muted); padding:24px; font-size:13px; border-top:1px solid var(--line)}

/* Flash */
.flash{padding:12px 16px; border-radius:10px; margin-bottom:18px; font-weight:600}
.flash-ok{background:rgba(55,211,154,.15); border:1px solid var(--ok); color:#bff7e2}
.flash-error{background:rgba(255,93,108,.15); border:1px solid var(--bad); color:#ffd2d7}
.flash-info{background:rgba(91,140,255,.15); border:1px solid var(--accent)}
.site-notice{padding:11px 14px; border-radius:10px; margin-bottom:14px; background:rgba(155,107,255,.15); border:1px solid var(--accent2); color:#e8dcff; font-weight:700}
.site-notice.warn{background:rgba(255,180,84,.13); border-color:var(--warn); color:#ffe0ae}
.ad-slot{min-height:86px; border:1px dashed var(--line); border-radius:10px; margin:0 0 18px; display:flex; align-items:center; justify-content:center; background:rgba(12,16,36,.72); color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.5px}
.ad-slot-footer{margin:18px auto 0; max-width:1040px}
.consent-banner{position:fixed; left:18px; right:18px; bottom:18px; z-index:30; max-width:980px; margin:auto; display:flex; align-items:center; justify-content:space-between; gap:18px; background:rgba(12,16,36,.96); border:1px solid var(--line); border-radius:12px; padding:14px 16px; box-shadow:0 18px 50px rgba(0,0,0,.45)}
.consent-banner p{margin:4px 0 0; color:var(--muted); line-height:1.45}
.consent-actions{display:flex; gap:10px; flex-shrink:0}
.legal-page{max-width:860px; margin:0 auto 18px; line-height:1.7}
.legal-page h2{margin-top:0}

/* Hero / Auth */
.hero{display:grid; grid-template-columns:1.2fr .8fr; gap:40px; align-items:center; padding-top:30px}
.hero-text h1{font-size:52px; margin:0 0 10px; color:#fff}
.hero-text h1 span{color:var(--accent)}
.tag{font-size:18px; color:var(--muted); margin-bottom:20px}
.features{list-style:none; padding:0; line-height:2; font-size:15px}
.auth-card{background:var(--panel); border:1px solid var(--line); border-radius:16px; padding:22px; box-shadow:0 20px 60px rgba(0,0,0,.4)}
.tabs{display:flex; gap:6px; margin-bottom:18px}
.tabs a{flex:1; text-align:center; padding:10px; border-radius:10px; background:var(--bg2); color:var(--muted); font-weight:700}
.tabs a.on{background:var(--accent); color:#fff}
.tabs a:hover{text-decoration:none}

/* Forms */
.form label,.form-inline label{display:flex; flex-direction:column; gap:5px; font-size:13px; color:var(--muted); font-weight:600; margin-bottom:12px}
.form-inline{display:flex; flex-wrap:wrap; gap:14px; align-items:flex-end}
input,select,textarea{
  background:var(--bg2); border:1px solid var(--line); color:var(--txt);
  padding:10px 12px; border-radius:9px; font-size:14px; font-family:inherit;
}
input:focus,select:focus,textarea:focus{outline:none; border-color:var(--accent)}
.oracle-admin{border-color:var(--accent2)}
.oracle-admin h3{color:var(--accent2)}
.hint{color:var(--muted); font-size:13px}
button{cursor:pointer; font-family:inherit; font-weight:700}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2)); color:#fff; border:0; padding:11px 18px; border-radius:10px; font-size:15px; width:100%}
.form-inline .btn-primary{width:auto}
.btn-small{background:var(--accent); color:#fff; border:0; padding:8px 14px; border-radius:8px}
.btn-small.ghost{background:transparent; border:1px solid var(--line); color:var(--muted)}
.inline{display:inline-flex; gap:6px; align-items:center; margin:0}

/* Headings */
.page-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:20px}
.page-head h2{margin:0}
.balance-chip{background:var(--panel); border:1px solid var(--line); padding:8px 14px; border-radius:30px}
.balance-chip.big{font-size:18px}
.balance-chip strong{color:var(--ok)}
.balance-chip.ok{border-color:var(--ok); color:var(--ok)}
.balance-chip.bad{border-color:var(--bad); color:var(--bad)}

.card{background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:18px 20px; margin-bottom:18px}
.card h3{margin:0 0 14px}
.cards2{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.cards2 .card{margin-bottom:0}

/* Planet cards */
.planet-card{display:flex; gap:20px; background:var(--panel); border:1px solid var(--line); border-radius:16px; padding:18px; margin-bottom:18px}
.planet-visual img{border-radius:50%; box-shadow:0 0 40px rgba(91,140,255,.25)}
.planet-body{flex:1}
.planet-title{display:flex; align-items:center; gap:12px}
.planet-title h3{margin:0}
.coords{color:var(--muted); font-family:monospace}
.tag-home{background:var(--accent2); color:#fff; font-size:11px; padding:2px 8px; border-radius:20px; font-weight:700}
.planet-meta{color:var(--muted); font-size:13px; margin:6px 0 14px}

.resources{display:flex; gap:12px; margin-bottom:14px; flex-wrap:wrap}
.res{flex:1; min-width:130px; background:var(--bg2); border:1px solid var(--line); border-radius:10px; padding:10px 12px; display:flex; flex-direction:column}
.res-name{font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.5px}
.res-val{font-size:20px; font-weight:800}
.res-rate{font-size:12px; color:var(--ok)}
.res-metal .res-val{color:var(--metal)}
.res-crystal .res-val{color:var(--crystal)}
.res-deut .res-val{color:var(--deut)}

.buildings{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.building{background:var(--bg2); border:1px solid var(--line); border-radius:10px; padding:12px; margin:0}
.b-info{display:flex; justify-content:space-between; align-items:center; margin-bottom:6px}
.b-level{font-size:12px; color:var(--accent); font-weight:700}
.b-cost{font-size:11px; color:var(--muted); margin-bottom:10px}
.building .btn-small{width:100%}

/* Tables */
table{width:100%; border-collapse:collapse}
th,td{text-align:left; padding:9px 10px; border-bottom:1px solid var(--line); font-size:14px}
th{color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.5px}
.empty{color:var(--muted); text-align:center; padding:20px}
.system .mini img{display:block; border-radius:50%}
.system tr.colonized{background:rgba(91,140,255,.06)}
.system .pos{color:var(--muted); width:40px}
.system .empty{padding:0; color:var(--muted)}

.navbar{display:flex; gap:14px; align-items:flex-end; margin-bottom:18px; flex-wrap:wrap}
.navbar label{display:flex; flex-direction:column; gap:5px; font-size:13px; color:var(--muted)}
.nav-arrows{margin-left:auto; display:flex; gap:14px}

.amt-in{color:var(--ok); font-weight:700}
.amt-out{color:var(--bad); font-weight:700}
.pending{color:var(--warn)}
.addr{word-break:break-all; background:var(--bg2); padding:10px; border-radius:8px; border:1px solid var(--line)}

/* Planet detail */
.planet-detail{display:flex; gap:30px; flex-wrap:wrap}
.planet-visual.big img{border-radius:50%; box-shadow:0 0 60px rgba(91,140,255,.3)}
.detail-info{flex:1; min-width:280px}
.props th{width:160px; color:var(--muted)}
.owned{color:var(--ok)} .unowned{color:var(--muted)}
.back{display:inline-block; margin-bottom:16px; color:var(--muted)}

/* Chain explorer */
.chain-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px}
.chain-stats div{background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:14px; text-align:center; color:var(--muted); font-size:13px; text-transform:uppercase; letter-spacing:.5px}
.chain-stats span{display:block; font-size:26px; font-weight:800; color:var(--txt); margin-bottom:4px}
.block{background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:16px; margin-bottom:14px}
.block-head{display:flex; justify-content:space-between; align-items:baseline}
.block-head h3{margin:0}
.when{color:var(--muted); font-size:13px}
.block-meta{font-size:12px; color:var(--muted); margin:8px 0; word-break:break-all; line-height:1.7}
.block-meta b{color:var(--accent)}

.lore-teaser{margin-top:18px}
.lore-teaser a{color:var(--accent2); font-weight:700; font-size:15px}

/* Lore */
.lore{max-width:900px; margin:0 auto}
.lore-title{font-size:40px; text-align:center; color:#fff; margin:10px 0 6px}
.lore-intro{text-align:center; color:var(--muted); font-size:17px; line-height:1.8; max-width:720px; margin:0 auto 30px; font-style:italic}
.lore-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.lore-card{background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:20px 22px}
.lore-card h3{margin:0 0 10px; color:var(--accent); font-size:19px}
.lore-card p{line-height:1.75; color:var(--txt); margin:0}
.oracle-card{grid-column:1 / -1; border-color:var(--accent2); background:linear-gradient(180deg,rgba(155,107,255,.10),var(--panel))}
.oracle-card h3{color:var(--accent2)}
.lore-link{display:inline-block; margin-top:12px; color:var(--accent2); font-weight:700}

/* Mundo */
.world-hero{display:flex; justify-content:space-between; align-items:center; gap:24px; margin-bottom:20px; padding:24px 0}
.world-hero h1{font-size:42px; margin:0 0 8px; color:#fff}
.world-hero p{margin:0; color:var(--muted); font-size:17px; line-height:1.7; max-width:720px}
.world-sigil{width:120px; height:120px; flex:0 0 auto; display:grid; place-items:center; border:1px solid var(--accent2); color:#fff; font-size:54px; font-weight:900; transform:rotate(45deg); background:linear-gradient(135deg,rgba(91,140,255,.22),rgba(55,211,154,.14)); box-shadow:0 0 36px rgba(91,140,255,.24); animation:sigilPulse 4s ease-in-out infinite}
.world-sigil{line-height:1}
.world-timeline{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:18px}
.world-timeline article{background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:16px}
.world-timeline span{color:var(--warn); font-weight:900; font-size:12px; letter-spacing:.8px}
.world-timeline h3{margin:8px 0}
.world-timeline p{margin:0; color:var(--muted); line-height:1.6}
.talent-grid{display:flex; flex-wrap:wrap; gap:8px; margin-top:12px}
.talent-grid span,.talent-strip strong{background:var(--bg2); border:1px solid var(--line); border-radius:8px; padding:8px 10px; color:var(--txt); font-weight:800}
.talent-strip{display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:18px; background:rgba(55,211,154,.08); border:1px solid rgba(55,211,154,.35); border-radius:12px; padding:12px 14px}
.talent-strip span{color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.6px}
.talent-strip a{margin-left:auto; font-weight:800}
.pet-row{display:flex; gap:12px; margin-top:14px}
.pet{width:72px; height:72px; border-radius:16px; display:grid; place-items:center; background:var(--bg2); border:1px solid var(--line); font-weight:900; color:#fff}
.pet.pulse{animation:petBounce 2.8s ease-in-out infinite}
.pet.sleepy{animation:petDrift 4s ease-in-out infinite}
.pet.bright{animation:petGlow 3s ease-in-out infinite}
.event-row{display:flex; gap:12px; align-items:flex-start; border-top:1px solid var(--line); padding:10px 0}
.event-row:first-of-type{border-top:0}
.event-row strong{min-width:74px; color:var(--warn)}
.event-row span{color:var(--muted); line-height:1.5}
@keyframes sigilPulse{0%,100%{transform:rotate(45deg) scale(1)}50%{transform:rotate(45deg) scale(1.04)}}
@keyframes petBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes petDrift{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
@keyframes petGlow{0%,100%{box-shadow:0 0 0 rgba(255,180,84,0)}50%{box-shadow:0 0 24px rgba(255,180,84,.35)}}

/* Feed del Oráculo */
.oracle-sub{color:var(--muted); margin:-8px 0 20px}
.oracle-feed{display:flex; flex-direction:column; gap:12px}
.oracle-event{display:flex; gap:14px; background:var(--panel); border:1px solid var(--line); border-left:3px solid var(--accent2); border-radius:10px; padding:14px 16px}
.oe-eye{color:var(--accent2); font-size:22px; line-height:1.2}
.oe-body{flex:1}
.oe-text{font-size:15px; margin-bottom:6px}
.oe-meta{display:flex; gap:12px; align-items:center; color:var(--muted); font-size:12px}
.badge-chain{background:rgba(155,107,255,.18); color:#d7c4ff; padding:2px 8px; border-radius:20px; font-weight:700}

.oracle-head{align-items:flex-start}
.sandtimer{min-width:140px; background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:10px 14px; text-align:center}
.sandtimer span{display:block; color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.5px}
.sandtimer strong{font-size:26px; color:var(--warn)}
.oracle-state{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:18px}
.oracle-state div{background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:14px}
.oracle-state span{display:block; color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.5px; margin-bottom:6px}
.oracle-state strong{font-size:17px}
.oracle-console,.bug-console{border-color:var(--accent2)}
button:disabled{opacity:.55; cursor:not-allowed}
.message-list{display:flex; flex-direction:column; gap:10px}
.message-row,.chronicle-row{background:var(--bg2); border:1px solid var(--line); border-radius:10px; padding:12px}
.message-row p,.chronicle-row p{margin:6px 0; line-height:1.55}
.message-row time{color:var(--muted); font-size:12px}
.align-good{color:var(--ok); font-weight:800}
.align-neutral{color:var(--warn); font-weight:800}
.align-bad{color:var(--bad); font-weight:800}
.integrity{font-weight:800; padding:10px 12px; border-radius:10px; background:var(--bg2)}
.integrity.ok{color:var(--ok); border:1px solid var(--ok)}
.integrity.bad{color:var(--bad); border:1px solid var(--bad)}
.bug-row{display:flex; flex-direction:column; gap:4px; border-top:1px solid var(--line); padding:10px 0}
.bug-row span{color:var(--muted); font-size:12px}
.oracle-feed.compact{max-height:520px; overflow:auto}
.chronicle-row small{color:var(--muted)}
.credential-box{width:100%; min-height:220px; font-family:Consolas,monospace; line-height:1.5}
.btn-linklike{display:inline-block; background:var(--accent); color:#fff; border:0; padding:11px 18px; border-radius:10px; font-weight:800}
.btn-linklike.ghost{background:transparent; border:1px solid var(--line); color:var(--muted)}
.recover-card{max-width:520px; margin:30px auto}
.kanban-board{display:grid; grid-template-columns:repeat(4,1fr); gap:12px}
.kanban-col{background:var(--bg2); border:1px solid var(--line); border-radius:10px; padding:10px}
.kanban-col h4{margin:0 0 10px; color:var(--muted); text-transform:uppercase; font-size:12px; letter-spacing:.5px}
.kanban-card{background:var(--panel); border:1px solid var(--line); border-left:3px solid var(--accent); border-radius:8px; padding:10px; margin-bottom:8px}
.kanban-card strong{display:block; font-size:13px; line-height:1.35}
.kanban-card span{display:block; color:var(--muted); font-size:11px; margin-top:6px}
.priority-high{border-left-color:var(--warn)}
.priority-critical{border-left-color:var(--bad)}
.vote-bars{display:grid; grid-template-columns:repeat(4,1fr); gap:12px}
.vote-bar{background:var(--bg2); border:1px solid var(--line); border-radius:10px; padding:12px; display:flex; justify-content:space-between; gap:10px; align-items:center}
.vote-bar span{color:var(--txt); font-weight:700; line-height:1.3}
.vote-bar strong{color:var(--warn); font-size:20px}
.dev-entry{display:flex; flex-direction:column; justify-content:center}

@media(max-width:820px){
  .lore-grid{grid-template-columns:1fr}
  .world-hero{align-items:flex-start}
  .world-sigil{width:86px; height:86px; font-size:38px}
  .world-timeline{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr}
  .cards2{grid-template-columns:1fr}
  .oracle-state{grid-template-columns:1fr 1fr}
  .kanban-board{grid-template-columns:1fr}
  .vote-bars{grid-template-columns:1fr}
  .buildings{grid-template-columns:1fr}
  .planet-card{flex-direction:column; align-items:center; text-align:center}
  .topbar{flex-wrap:wrap}
  .talent-strip a{margin-left:0; width:100%}
  .pet-row{justify-content:space-between}
  .consent-banner{position:static; margin:18px; flex-direction:column; align-items:stretch}
  .consent-actions{width:100%}
  .consent-actions a{flex:1; text-align:center}
}
