/* =============================================
   EMPIRE LORDS - CSS Theme v1.0
   Palette: or #D4A84B, noir #000, bleu #1A2A4A
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Cinzel+Decorative:wght@700&family=Open+Sans:wght@400;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --gold:#D4A84B;
  --gold-light:#F2D07B;
  --gold-dark:#8C6A20;
  --blue:#1A2A4A;
  --blue-light:#2A4A7A;
  --black:#000000;
  --bg:#050305;
  --card-bg:rgba(0,0,0,.82);
  --border-gold:rgba(212,168,75,.5);
  --border-dark:rgba(212,168,75,.15);
  --text:#C8A87A;
  --text-light:#8B7A5A;
  --text-gold:#F2D07B;
  --red:#8E1E1E;
  --red-light:#E05050;
  --green:#2A4A1A;
  --green-light:#5A8A3A;
  --shadow:rgba(0,0,0,.8);
  /* Compat */
  --brown-dark:#000;
  --brown-mid:#3A2800;
  --gold-light:#F2D07B;
  --parchment:#0A0608;
  --parchment2:#0D080C;
  --parchment3:#150F14;
  --stone:#6B5A3A;
  --green-dark:#1A3A0A;
  --green-mid:#3A5A2A;
  --red-dark:#5A0F0F;
  --text-main:#C8A87A;
  --border:#3A2800;
  --bar1:#D4A84B;
  --bar2:#F2D07B;
  --bar-bg:rgba(0,0,0,.5);
  --vbrown:#D4A84B;
  --vbrown2:#C8A87A;
  --vbrown3:#8B7A5A;
  --p0:#0A0608;
  --p1:#0D080C;
  --p2:#150F14;
  --p3:#3A2800;
}

body{
  font-family:'Open Sans',Georgia,serif;
  background-color:#050305;
  background-image:url('../img/fond.png');
  background-size:cover;
  background-position:center top;
  background-attachment:fixed;
  background-repeat:no-repeat;
  color:#C8A87A;
  min-height:100vh;
}

/* ===== HEADER ===== */
.site-header{
  background:#000;
  border-bottom:2px solid var(--gold);
  padding:8px 20px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  box-shadow:0 2px 20px rgba(212,168,75,.15);
}
.header-brand{display:flex;align-items:center;gap:10px}
.castle-icon{display:none}
.logo-img{height:48px;object-fit:contain}
.site-title{
  font-family:'Cinzel Decorative',serif;
  font-size:1.3rem;color:var(--gold-light);letter-spacing:2px;
  text-shadow:0 0 20px rgba(212,168,75,.4);
}
.resource-bar{
  display:flex;gap:8px;flex-wrap:wrap;
  background:rgba(0,0,0,.6);
  border:1px solid var(--border-dark);
  border-radius:4px;padding:5px 12px;flex:1;justify-content:center;
}
.res{font-size:.82rem;color:var(--text);white-space:nowrap;display:flex;align-items:center;gap:4px}
.res-icon{width:20px;height:20px;min-width:20px;min-height:20px;max-width:20px;max-height:20px;object-fit:contain;vertical-align:middle;display:inline-block;flex-shrink:0}
.res b{color:var(--gold);margin-left:3px}
.res.gold b{color:var(--gold-light)}
.header-user{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.village-name{font-size:.8rem;color:var(--text-light)}
.player-name{font-size:.8rem;color:var(--gold);cursor:pointer;text-decoration:none}
.player-name:hover{color:var(--gold-light)}
.msg-link{color:var(--gold);text-decoration:none;font-size:1.1rem;position:relative}
.msg-link sup{background:var(--red);color:#fff;font-size:.65rem;border-radius:50%;padding:1px 4px;position:absolute;top:-4px;right:-8px}
.attack-badge{background:var(--red);color:var(--gold-light);font-size:.65rem;border-radius:10px;padding:1px 6px;margin-left:4px;font-weight:700;animation:pulse-red 1s ease-in-out infinite;display:inline-block;vertical-align:middle}
@keyframes pulse-red{0%,100%{box-shadow:0 0 0 0 rgba(142,30,30,.5)}50%{box-shadow:0 0 0 4px rgba(142,30,30,0)}}
.btn-logout{background:#1A0000;color:var(--text);padding:5px 14px;border-radius:4px;text-decoration:none;font-size:.8rem;border:1px solid var(--red)}
.btn-logout:hover{background:#2A0000;color:var(--gold-light)}

/* ===== NAVIGATION ===== */
.main-nav{
  background:#000;
  border-bottom:1px solid var(--border-dark);
  display:flex;flex-wrap:wrap;padding:3px 10px;gap:2px;
}
.main-nav a{
  color:var(--text-light);text-decoration:none;
  padding:5px 8px;border-radius:4px;
  font-family:'Cinzel',serif;font-size:.62rem;
  transition:all .15s;border:1px solid transparent;
  letter-spacing:.5px;
  display:flex;align-items:center;gap:5px;
}
.main-nav a img{width:20px;height:20px;object-fit:contain;filter:brightness(.7)}
.main-nav a:hover,
.main-nav a.active{
  background:rgba(212,168,75,.08);
  border-color:var(--gold);color:var(--gold-light);
  box-shadow:0 0 8px rgba(212,168,75,.1);
}
.main-nav a:hover img,
.main-nav a.active img{filter:brightness(1)}

/* ===== MAIN ===== */
.main-content{max-width:1200px;margin:20px auto;padding:0 16px 40px;color:var(--text)}

/* ===== CARDS ===== */
.card{
  background:rgba(0,0,0,.82);
  color:var(--text);
  border:1px solid var(--border-dark);
  border-radius:6px;padding:16px;margin-bottom:14px;
  position:relative;
  box-shadow:0 4px 20px rgba(0,0,0,.6);
}
.card::before{
  content:'';position:absolute;inset:0;border-radius:6px;
  background:linear-gradient(135deg,rgba(212,168,75,.08) 0%,transparent 40%,transparent 60%,rgba(212,168,75,.04) 100%) border-box;
  pointer-events:none;
}
.card-title{
  font-family:'Cinzel',serif;font-size:.95rem;
  color:var(--gold);
  border-bottom:1px solid var(--border-dark);
  padding-bottom:10px;margin-bottom:14px;
  position:relative;letter-spacing:.5px;
  display:flex;align-items:center;gap:8px;
}
.card-title::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.3;
}

/* ===== GRIDS ===== */
.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}

/* ===== BUILDING CARD ===== */
.building-card{
  background:rgba(0,0,0,.7);
  border:1px solid var(--border-dark);
  border-radius:5px;padding:14px;
  transition:transform .15s,box-shadow .15s,border-color .15s;
  color:var(--text);
}
.building-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.6);border-color:var(--gold)}
.building-card .bld-icon{font-size:2rem;display:block;text-align:center;margin-bottom:8px}
.building-card h3{font-family:'Cinzel',serif;font-size:.88rem;text-align:center;color:var(--gold)}
.building-card .level-badge{display:block;width:fit-content;background:rgba(0,0,0,.6);color:var(--gold);font-size:.7rem;padding:2px 8px;border-radius:10px;margin:6px auto;border:1px solid var(--border-dark)}
.building-card .prod-rate{font-size:.75rem;color:var(--green-light);text-align:center;margin:4px 0}
.building-card .upgrade-in{font-size:.72rem;color:var(--gold);text-align:center;margin:4px 0;font-style:italic}
.building-card .cost-list{font-size:.72rem;color:var(--text-light);margin:8px 0}
.building-card .cost-list span{margin-right:8px}

/* ===== BUTTONS ===== */
.btn{
  display:inline-block;font-family:'Cinzel',serif;
  font-size:.8rem;padding:8px 16px;border-radius:4px;
  border:1px solid;cursor:pointer;text-decoration:none;
  text-align:center;transition:all .15s;letter-spacing:.5px;
}
.btn-primary{
  background:linear-gradient(180deg,#C89030,#7A5010);
  border-color:var(--gold);color:#000;font-weight:700;
  box-shadow:0 0 10px rgba(212,168,75,.2),inset 0 1px 0 rgba(255,220,100,.2);
}
.btn-primary:hover{background:linear-gradient(180deg,#D8A040,#8A6020);box-shadow:0 0 16px rgba(212,168,75,.35);transform:translateY(-1px)}
.btn-secondary{background:rgba(0,0,0,.5);border-color:var(--border-dark);color:var(--text-light)}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.btn-danger{
  background:linear-gradient(180deg,#6A0000,#2A0000);
  border-color:#8E1E1E;color:var(--gold-light);
  box-shadow:0 0 8px rgba(142,30,30,.2);
}
.btn-danger:hover{background:linear-gradient(180deg,#8A0000,#3A0000)}
.btn-sm{font-size:.7rem;padding:5px 10px}
.btn-full{width:100%;display:block}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}

/* ===== FORMS ===== */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-family:'Cinzel',serif;font-size:.8rem;color:var(--gold);margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:8px 12px;
  border:1px solid var(--border-dark);border-radius:4px;
  background:rgba(0,0,0,.6);color:var(--text);
  font-family:'Open Sans',serif;font-size:.85rem;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 8px rgba(212,168,75,.2);
}
.form-group input[type="number"]{max-width:120px}

/* ===== FLASH ===== */
.flash{padding:10px 16px;border-radius:4px;margin-bottom:14px;font-weight:600;border:1px solid}
.flash-success{background:rgba(30,60,20,.3);border-color:#2A4A1A;color:#7ABF5A}
.flash-error{background:rgba(60,0,0,.3);border-color:#5A0F0F;color:#E05050}

/* ===== TABLES ===== */
.troops-table{width:100%;border-collapse:collapse}
.troops-table th{background:rgba(0,0,0,.7);color:var(--gold);font-family:'Cinzel',serif;font-size:.75rem;padding:10px;text-align:center;border-bottom:1px solid var(--border-dark)}
.troops-table td{padding:10px;text-align:center;border-bottom:1px solid rgba(212,168,75,.06);font-size:.82rem;color:var(--text)}
.troops-table tr:hover td{background:rgba(212,168,75,.04)}
.unit-icon{font-size:1.4rem}
.rank-table{width:100%;border-collapse:collapse}
.rank-table th{background:rgba(0,0,0,.7);color:var(--gold);font-family:'Cinzel',serif;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-dark)}
.rank-table td{padding:10px 14px;border-bottom:1px solid rgba(212,168,75,.06);font-size:.85rem;color:var(--text)}
.rank-table tr:nth-child(even) td{background:rgba(212,168,75,.02)}
.rank-table tr.me td{background:rgba(212,168,75,.06)}
.rank-num{font-family:'Cinzel',serif;font-size:1rem;font-weight:700;color:var(--gold)}

/* ===== MAP ===== */
.world-map{display:grid;gap:2px;margin:0 auto;max-width:600px}
.map-cell{width:28px;height:28px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:.65rem;cursor:default;border:1px solid rgba(0,0,0,.3);transition:transform .1s}
.map-cell:hover{transform:scale(1.3);z-index:2;position:relative}
.map-cell.empty{background:#0A150A}
.map-cell.my-village{background:var(--gold);color:#000;font-weight:bold}
.map-cell.other-village{background:#3A0000;color:var(--gold-light)}
.map-cell.ally-village{background:#0A2A0A;color:#7ABF5A}
.map-legend{display:flex;gap:16px;justify-content:center;margin-top:10px;flex-wrap:wrap;font-size:.78rem;color:var(--text-light)}
.map-legend span{display:flex;align-items:center;gap:6px}
.legend-box{width:14px;height:14px;border-radius:2px}

/* ===== BATTLE REPORT ===== */
.report-card{border-left:3px solid var(--border-dark);margin-bottom:10px}
.report-card.win{border-color:#2A4A1A}
.report-card.loss{border-color:#5A0F0F}
.report-card.draw{border-color:var(--gold)}

/* ===== MARKET ===== */
.offer-row{display:flex;align-items:center;gap:10px;padding:10px;border-bottom:1px solid rgba(212,168,75,.06);flex-wrap:wrap}
.offer-row:last-child{border-bottom:none}
.offer-res{font-size:1.3rem}

/* ===== ALLIANCE ===== */
.alliance-member{display:flex;justify-content:space-between;padding:8px 12px;border-bottom:1px solid rgba(212,168,75,.06);color:var(--text)}

/* ===== PROGRESS ===== */
.progress-bar{background:rgba(0,0,0,.5);border-radius:3px;height:6px;overflow:hidden;margin:4px 0;border:1px solid var(--border-dark)}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light));border-radius:3px;transition:width .3s}

/* ===== TIMER ===== */
.timer{font-family:'Cinzel',serif;font-size:1rem;color:var(--gold);font-weight:700;display:inline-block;min-width:80px}

/* ===== FOOTER ===== */
.site-footer{
  background:#000;border-top:1px solid var(--border-dark);
  color:#3A2A10;text-align:center;
  padding:14px;font-size:.75rem;margin-top:40px;
}
.site-footer a{color:var(--gold);text-decoration:none}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-box{
  background:#000;
  border:1px solid var(--border-gold);
  border-radius:8px;padding:36px;width:100%;max-width:420px;
  box-shadow:0 8px 40px rgba(0,0,0,.9),0 0 60px rgba(212,168,75,.06);
  text-align:center;position:relative;
}
.login-box::before{
  content:'';position:absolute;inset:0;border-radius:8px;
  background:linear-gradient(135deg,rgba(212,168,75,.08) 0%,transparent 50%) border-box;
  pointer-events:none;
}
.login-box h1{font-family:'Cinzel Decorative',serif;font-size:1.5rem;color:var(--gold-light);margin-bottom:6px;text-shadow:0 0 20px rgba(212,168,75,.4)}
.login-box .subtitle{color:var(--text-light);font-size:.85rem;margin-bottom:22px}
.login-tabs{display:flex;border-bottom:1px solid var(--border-dark);margin-bottom:18px}
.login-tab{flex:1;padding:9px;font-family:'Cinzel',serif;font-size:.8rem;cursor:pointer;color:var(--text-light);background:none;border:none;transition:all .15s}
.login-tab.active{color:var(--gold-light);border-bottom:2px solid var(--gold);margin-bottom:-1px}
.tab-pane{display:none}
.tab-pane.active{display:block}

/* ===== VILLAGE PAGE ===== */
.village-wrap{display:grid;grid-template-columns:380px 1fr;gap:16px;align-items:start}
.parch-window{
  background:rgba(0,0,0,.82);
  border:1px solid var(--border-dark);
  border-radius:8px;overflow:hidden;margin-bottom:12px;color:var(--text);
  position:relative;
}
.parch-window::before{
  content:'';position:absolute;inset:0;border-radius:8px;
  background:linear-gradient(135deg,rgba(212,168,75,.06) 0%,transparent 40%) border-box;
  pointer-events:none;
}
.parch-window-title{
  padding:12px 16px 10px;border-bottom:1px solid var(--border-dark);
  font-family:'Cinzel',serif;font-size:.95rem;font-weight:700;
  color:var(--gold);display:flex;align-items:center;gap:8px;
  position:relative;
}
.parch-window-title::after{content:'';position:absolute;bottom:0;left:16px;right:16px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.25}
.parch-window-sub{padding:7px 16px;border-bottom:1px solid rgba(212,168,75,.06);font-size:.78rem;color:var(--text-light);display:flex;gap:12px}
.section-title{padding:10px 16px 6px;font-family:'Cinzel',serif;font-size:.68rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:1.5px}
.res-card{margin:0 12px 8px;background:rgba(0,0,0,.5);border:1px solid var(--border-dark);border-radius:5px;padding:10px 14px}
.res-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.res-card-label{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-light)}
.res-card-label .icon{font-size:1rem}
.res-card-rate{font-size:.72rem;color:var(--green-light);font-style:italic}
.res-card-amount{font-family:'Cinzel',serif;font-size:1rem;font-weight:700;color:var(--gold);margin-bottom:5px}
.res-card-amount .cap{font-size:.65rem;font-weight:400;color:var(--text-light)}
.res-bar-bg{background:rgba(0,0,0,.5);border-radius:3px;height:6px;overflow:hidden;border:1px solid rgba(212,168,75,.1)}
.res-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light));transition:width .4s}
.bld-card{margin:0 12px 8px;background:rgba(0,0,0,.4);border:1px solid var(--border-dark);border-radius:5px;padding:9px 13px;display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;transition:border-color .15s;cursor:pointer}
.bld-card:hover{border-color:var(--gold)}
.bld-card .bld-icon{font-size:1.4rem;flex-shrink:0}
.bld-card .bld-info{flex:1}
.bld-card .bld-name{font-family:'Cinzel',serif;font-size:.8rem;color:var(--gold);font-weight:600;margin-bottom:2px}
.bld-card .bld-sub{font-size:.68rem;color:var(--text-light)}
.bld-card .bld-sub .prod{color:var(--green-light);margin-left:6px}
.bld-level{font-family:'Cinzel',serif;font-size:.72rem;color:var(--text-light);text-align:right;flex-shrink:0;min-width:46px}
.bld-level .lvnum{font-size:1.05rem;font-weight:700;color:var(--gold-light);display:block}
.bld-level .lvmax{font-size:.58rem;color:var(--text-light)}
.bld-bar-bg{background:rgba(0,0,0,.4);border-radius:2px;height:3px;margin-top:4px;overflow:hidden}
.bld-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--gold-dark),var(--gold))}
.upgrading-badge{background:rgba(140,106,32,.3);color:var(--gold);font-size:.55rem;padding:1px 5px;border-radius:4px;margin-left:4px;vertical-align:middle;border:1px solid rgba(212,168,75,.3)}
.troop-card{margin:0 12px 8px;background:rgba(0,0,0,.4);border:1px solid var(--border-dark);border-radius:5px;padding:8px 13px;display:flex;justify-content:space-between;align-items:center}
.troop-card .tname{font-size:.8rem;color:var(--text);display:flex;align-items:center;gap:6px}
.troop-card .tqty{font-family:'Cinzel',serif;font-size:.95rem;font-weight:700;color:var(--gold)}
.queue-card{margin:0 12px 8px;background:rgba(0,0,0,.4);border:1px solid rgba(212,168,75,.3);border-radius:5px;padding:9px 13px;display:flex;align-items:center;gap:10px}
.queue-card .qtimer{margin-left:auto;font-family:'Cinzel',serif;font-size:.88rem;color:var(--red-light);font-weight:700;min-width:70px;text-align:right}
.navlink{display:block;background:rgba(0,0,0,.4);border:1px solid var(--border-dark);border-radius:5px;padding:7px 12px;font-family:'Cinzel',serif;font-size:.72rem;color:var(--gold);text-decoration:none;margin:0 10px 6px;transition:border-color .15s}
.navlink:hover{border-color:var(--gold);color:var(--gold-light)}

/* ===== CHAT ===== */
.chat-box{background:rgba(0,0,0,.6);border:1px solid var(--border-dark);border-radius:5px;padding:12px;max-height:300px;overflow-y:auto;margin-bottom:12px}
.chat-msg{margin-bottom:8px;font-size:.82rem;color:var(--text)}
.chat-msg .author{font-family:'Cinzel',serif;font-size:.75rem;color:var(--gold);font-weight:600}
.chat-msg .time{font-size:.65rem;color:var(--text-light);margin-left:8px}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){.village-wrap{grid-template-columns:1fr}}
@media(max-width:768px){
  .site-header{flex-direction:column;align-items:flex-start;gap:8px;padding:8px 12px}
  .logo-img{height:36px}
  .site-title{font-size:1rem}
  .resource-bar{flex:none;width:100%;padding:4px 8px;gap:6px}
  .res{font-size:.72rem}
  .header-user{width:100%;justify-content:space-between}
  .village-name{display:none}
  .main-nav{padding:2px 4px;gap:1px}
  .main-nav a{padding:4px 6px;font-size:.58rem;letter-spacing:0}
  .main-nav a img{width:16px;height:16px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}