/* Realm of Levies — shared theme
   Dark iron + parchment + gold, with faction accents (Goth green / Roman red). */
:root{
  --bg:#14110d; --bg2:#1b1711; --panel:#221d16; --panel2:#2b251c;
  --line:#473d30; --ink:#e9e2d0; --muted:#9d9276; --gold:#d8b35a; --gold-d:#b9923f;
  --goth:#7bb05a; --goth-d:#3f6b3a; --rome:#c1564e; --rome-d:#9a3b34;
  --shadow:0 10px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 500px at 50% -8%, #2a2114 0%, transparent 60%),
    linear-gradient(180deg,#14110d 0%, #100d09 100%);
  color:var(--ink);
  font-family:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,ui-serif,serif;
  min-height:100vh; line-height:1.6;
}
h1,h2,h3,.display{
  font-family:"Cinzel","Trajan Pro",Georgia,ui-serif,serif;
  letter-spacing:.04em; font-weight:600; margin:0;
}
a{color:var(--gold); text-decoration:none}
a:hover{color:#ecd089}
.wrap{max-width:1120px; margin:0 auto; padding:0 20px}

/* top bar */
.topbar{display:flex; align-items:center; gap:16px; padding:16px 20px; max-width:1120px; margin:0 auto;}
.brand{display:flex; align-items:center; gap:11px; font-family:"Cinzel",Georgia,serif; font-size:19px; letter-spacing:.08em; color:var(--ink)}
.brand .crest{width:30px;height:30px;flex:0 0 auto}
.topbar .spacer{flex:1}
.navlinks{display:flex; gap:10px; align-items:center}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:8px; cursor:pointer; border-radius:9px;
  padding:10px 18px; font-size:14.5px; font-family:inherit; border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel2),var(--panel)); color:var(--ink); transition:.15s;}
.btn:hover{border-color:var(--gold-d); color:#fff}
.btn:active{transform:translateY(1px)}
.btn-gold{background:linear-gradient(180deg,#e7c266,#cf9f3f); color:#2b2009; border-color:#a87f31; font-weight:700}
.btn-gold:hover{color:#1c1503; filter:brightness(1.06)}
.btn-ghost{background:transparent}
.btn-lg{padding:14px 26px; font-size:16px}
.btn-block{width:100%; justify-content:center}

/* hero / landing */
.hero{position:relative; overflow:hidden; border-bottom:1px solid var(--line)}
.hero .scene{display:block; width:100%; height:auto}
.hero .veil{position:absolute; inset:0; background:
  radial-gradient(800px 380px at 50% 38%, transparent 0%, rgba(10,8,6,.20) 70%, rgba(10,8,6,.7) 100%);
  pointer-events:none}
.hero .copy{position:absolute; inset:0; display:flex; flex-direction:column; align-items:center;
  justify-content:center; text-align:center; padding:24px; pointer-events:none}
.hero .copy > *{pointer-events:auto}
.hero h1{font-size:clamp(34px,7vw,76px); color:#f3ead2; text-shadow:0 3px 18px rgba(0,0,0,.7), 0 0 2px #000;}
.hero .tag{color:#e8dcc0; font-size:clamp(15px,2.2vw,21px); margin-top:10px; max-width:680px;
  text-shadow:0 2px 10px rgba(0,0,0,.8)}
.hero .era{color:var(--gold); letter-spacing:.34em; font-size:13px; margin-bottom:8px; text-transform:uppercase;
  font-family:"Cinzel",serif; text-shadow:0 2px 8px #000}
.hero .cta{margin-top:26px; display:flex; gap:14px; flex-wrap:wrap; justify-content:center}
.vs{font-family:"Cinzel",serif; font-weight:700}

/* sections */
.section{padding:60px 0}
.section h2{font-size:clamp(24px,4vw,34px); color:#f0e6cd; text-align:center}
.lead{color:var(--muted); text-align:center; max-width:680px; margin:12px auto 0; font-size:16px}
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:38px}
@media(max-width:780px){ .cards{grid-template-columns:1fr} }
.card{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line);
  border-radius:14px; padding:22px 22px 24px; box-shadow:var(--shadow)}
.card .ic{width:34px;height:34px;margin-bottom:10px}
.card h3{font-size:18px; color:#efe4ca; margin-bottom:7px}
.card p{color:var(--muted); font-size:14.5px; margin:0}

.roster{display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:36px}
@media(max-width:680px){ .roster{grid-template-columns:1fr} }
.faction{border:1px solid var(--line); border-radius:14px; padding:22px; background:var(--panel)}
.faction.goth{border-color:#3f5b32; box-shadow:inset 0 0 40px rgba(123,176,90,.06)}
.faction.rome{border-color:#6b322d; box-shadow:inset 0 0 40px rgba(193,86,78,.06)}
.faction h3{font-size:20px; display:flex; align-items:center; gap:10px}
.faction .dot{width:13px;height:13px;border-radius:50%}
.faction ul{margin:14px 0 0; padding-left:18px; color:var(--muted); font-size:14px}
.faction li{margin:5px 0}

/* auth */
.authpage{display:flex; min-height:calc(100vh - 70px); align-items:center; justify-content:center; padding:30px 20px}
.authcard{width:100%; max-width:430px; background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line); border-radius:16px; padding:30px 30px 26px; box-shadow:var(--shadow)}
.authcard h2{font-size:25px; color:#f0e6cd; text-align:center}
.authcard .sub{color:var(--muted); text-align:center; font-size:14px; margin:6px 0 22px}
.field{margin-bottom:16px}
.field label{display:block; font-size:13px; color:var(--muted); margin-bottom:6px; letter-spacing:.02em}
.field input{width:100%; background:#17130e; border:1px solid var(--line); color:var(--ink);
  border-radius:9px; padding:11px 13px; font-size:15px; font-family:inherit}
.field input:focus{outline:none; border-color:var(--gold-d); box-shadow:0 0 0 3px rgba(216,179,90,.12)}
.err{color:#ef9a8e; font-size:13px; margin-top:6px}
.checkrow{display:flex; align-items:center; gap:8px; color:var(--muted); font-size:13.5px; margin-bottom:16px}
.altline{text-align:center; color:var(--muted); font-size:14px; margin-top:18px}

/* flash */
.flash{max-width:1120px; margin:16px auto 0; padding:0 20px}
.flash .msg{background:rgba(123,176,90,.12); border:1px solid #4f7a3e; color:#cfe6bd;
  border-radius:10px; padding:11px 15px; font-size:14px}

/* dashboard */
.warroom{padding:34px 0 70px}
.greet{font-size:clamp(24px,4vw,34px); color:#f0e6cd}
.greet small{display:block; font-family:inherit; color:var(--muted); font-size:15px; letter-spacing:0; margin-top:6px; font-weight:400}
.panels{display:grid; grid-template-columns:1.3fr 1fr; gap:20px; margin-top:26px}
@media(max-width:820px){ .panels{grid-template-columns:1fr} }
.panel{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line);
  border-radius:14px; padding:22px; box-shadow:var(--shadow)}
.panel h3{font-size:17px; color:#efe4ca; margin-bottom:14px}
.stat{display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px dashed #36302540; font-size:15px}
.stat:last-child{border-bottom:none}
.stat b{color:var(--gold)}
.bannerpick{display:flex; gap:12px; margin:14px 0 6px}
.bannerpick button{flex:1; padding:14px; border-radius:11px; border:1px solid var(--line); cursor:pointer;
  background:var(--panel2); color:var(--ink); font-family:inherit; font-size:15px; transition:.15s}
.bannerpick button.goth.active{border-color:var(--goth); box-shadow:inset 0 0 26px rgba(123,176,90,.14); color:#cfe6bd}
.bannerpick button.rome.active{border-color:var(--rome); box-shadow:inset 0 0 26px rgba(193,86,78,.14); color:#f1c4bc}
.bannerpick button:hover{border-color:var(--gold-d)}

footer{border-top:1px solid var(--line); padding:26px 0 50px; color:var(--muted); font-size:13px}
footer .wrap{display:flex; gap:16px; flex-wrap:wrap; align-items:center}
.histnote{font-style:italic; max-width:760px; line-height:1.7}

/* campaign chooser (dashboard / War Room) */
.campaigns { display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:18px; margin-top:22px; }
.ccard { position:relative; background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line);
  border-radius:14px; overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; }
.ccard.live { cursor:pointer; transition:border-color .15s, transform .08s; text-decoration:none; color:inherit; }
.ccard.live:hover { border-color:var(--gold-d); }
.ccard.live:hover .cbanner svg { transform:scale(1.05); }
.ccard .cbanner { height:120px; display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--line);
  background:radial-gradient(180px 120px at 50% 35%, #2a2114 0%, #16130d 80%); }
.ccard .cbanner svg { height:78px; transition:transform .3s; }
.ccard .cbody { padding:16px 18px 18px; flex:1; display:flex; flex-direction:column; }
.ccard .cera { font-size:11px; letter-spacing:.45px; text-transform:uppercase; color:var(--gold); }
.ccard h3 { font-size:19px; margin:4px 0 7px; color:#efe4ca; font-family:"Cinzel",Georgia,serif; }
.ccard .cblurb { font-size:13.5px; color:var(--muted); line-height:1.55; flex:1; }
.ccard .cfoot { margin-top:15px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.ccard .cprog { font-size:12.5px; color:var(--muted); }
.ccard .cprog b { color:var(--gold); }
.ccard.locked { opacity:.72; }
.ccard.locked .cbanner svg { filter:grayscale(.75) brightness(.7); }
.ccard .soon { font-size:11.5px; color:var(--muted); border:1px dashed var(--line); border-radius:20px; padding:5px 12px; }
.commander { margin-top:30px; }

/* Codex (encyclopedia) */
.codex-head { display:flex; align-items:baseline; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-top:8px; }
.codex-head h1 { font-size:clamp(24px,4vw,32px); color:#f0e6cd; }
.codex-prog { color:var(--muted); font-size:13.5px; }
.codex-prog b { color:var(--gold); }
.codex-tabs { display:flex; gap:8px; margin:18px 0 4px; flex-wrap:wrap; }
.codex-tabs .ctab { background:var(--panel2); border:1px solid var(--line); color:var(--ink); border-radius:9px; padding:8px 15px; font-size:14px; cursor:pointer; font-family:inherit; }
.codex-tabs .ctab:hover { border-color:var(--gold-d); }
.codex-tabs .ctab.active { background:var(--gold); color:#2b2009; border-color:#a87f31; font-weight:600; }
.cx-section { margin-top:18px; }
.cx-section.hidden { display:none; }
.cx-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:820px){ .cx-grid{ grid-template-columns:1fr; } }
.cx-entry { position:relative; background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:12px; padding:18px 20px; box-shadow:var(--shadow); overflow:hidden; }
.cx-entry .cx-meta { font-size:11px; letter-spacing:.45px; text-transform:uppercase; color:var(--gold); }
.cx-entry h3 { font-family:"Cinzel",Georgia,serif; margin:4px 0 8px; font-size:18px; color:#efe4ca; }
.cx-entry .cx-body { font-size:14px; color:#d3cab4; line-height:1.62; margin:0; }
.cx-src { margin-top:13px; border-top:1px dashed var(--line); padding-top:10px; }
.cx-src .lbl { font-size:10.5px; text-transform:uppercase; letter-spacing:.5px; color:var(--muted); }
.cx-src ul { margin:6px 0 0; padding-left:17px; }
.cx-src li { font-size:12.5px; color:var(--muted); margin:3px 0; line-height:1.4; }
.cx-src a { color:var(--gold); }
.cx-entry.locked .cx-reveal { filter:blur(5px); opacity:.32; user-select:none; pointer-events:none; }
.cx-lock { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; padding:20px; }
.cx-lock span { background:rgba(16,13,10,0.72); border:1px solid var(--line); border-radius:10px; padding:10px 15px; font-size:13px; color:var(--ink); }
.coming { color:var(--muted); font-style:italic; padding:22px 4px; }
.codex-intro { background:linear-gradient(180deg,var(--panel2),var(--panel)); border:1px solid var(--line); border-left:3px solid var(--gold); border-radius:10px; padding:13px 16px; margin-top:16px; }
.codex-intro .lbl { font-size:10.5px; text-transform:uppercase; letter-spacing:.5px; color:var(--gold); margin-bottom:7px; }
.codex-intro ul { margin:0; padding-left:17px; }
.codex-intro li { font-size:13px; margin:4px 0; }
.codex-intro a { color:var(--gold); }

/* flat-vector art idle motion (shared with the game look) */
.flag { transform-origin:8px -20px; animation:sway 2.6s ease-in-out infinite; }
@keyframes sway { 0%,100%{ transform:skewX(0deg);} 50%{ transform:skewX(-10deg);} }

/* clickable Codex cards + reward modal */
.cx-card { display:block; width:100%; text-align:left; background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:12px; overflow:hidden; box-shadow:var(--shadow); cursor:pointer; padding:0; color:inherit; position:relative; transition:border-color .15s, transform .08s; font-family:inherit; }
.cx-card:hover { border-color:var(--gold-d); }
.cx-card:hover .cx-cardart { animation-duration:2.6s; }
.cx-cardart { width:100%; height:104px; display:block; background:#1b1610; border-bottom:1px solid var(--line); transform-origin:50% 80%; animation:mbreathe 5s ease-in-out infinite; }
.cx-cardbody { padding:12px 15px 14px; }
.cx-cardbody .cx-meta { font-size:10.5px; letter-spacing:.45px; text-transform:uppercase; color:var(--gold); }
.cx-cardbody .cx-title { font-family:"Cinzel",Georgia,serif; font-size:16px; color:#efe4ca; margin:3px 0 0; }
.cx-cardbody .cx-more { font-size:12px; color:var(--muted); margin-top:9px; }
.cx-card.locked { cursor:not-allowed; opacity:.72; }
.cx-card.locked .cx-cardart { filter:grayscale(.7) brightness(.62); }
.cx-card .cx-lockpill { position:absolute; top:8px; right:8px; background:rgba(16,13,10,.78); border:1px solid var(--line); border-radius:20px; padding:3px 10px; font-size:11px; color:var(--ink); }
.cx-modal { position:fixed; inset:0; background:rgba(10,8,6,.74); display:flex; align-items:center; justify-content:center; z-index:60; padding:24px; }
.cx-modal.hidden { display:none; }
.cx-modal-card { position:relative; width:min(620px,96%); max-height:88vh; overflow:auto; background:var(--panel); border:1px solid var(--line); border-radius:16px; box-shadow:0 24px 70px rgba(0,0,0,.6); }
.cx-modalart { width:100%; height:210px; display:block; background:#1b1610; border-bottom:1px solid var(--line); }
.cx-close { position:absolute; top:10px; right:10px; z-index:2; background:rgba(20,17,14,.7); }
.cx-modal-body { padding:20px 24px 24px; }
.cx-modal-body .cx-meta { font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--gold); }
.cx-modal-body h2 { font-family:"Cinzel",Georgia,serif; font-size:24px; color:#f0e6cd; margin:5px 0 13px; }
.cx-modal-body .cx-fulltext { font-size:15px; line-height:1.72; color:#d8cfb8; margin:0; }
.ov-links { margin:0; padding-left:18px; }
.ov-links li { font-size:14px; margin:8px 0; line-height:1.45; }
.ov-links a { color:var(--gold); }
