/* ============================================================
   Nusantara: Gubernur Simulator  —  main.css
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@600;700;900&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  --gold:    #f5c842; --gold-dk: #c9952a;
  --green:   #2ecc71; --red:     #e74c3c;
  --blue:    #3498db; --purple:  #9b59b6;
  --bg:      #080e1b; --bg2:     #0d1628; --bg3:     #111e38;
  --card:    #131f38; --card2:   #182847;
  --border:  rgba(245,200,66,.12);
  --text:    #dde4f5; --text2:   #7a8baa; --text3:   #3f5070;
  --r: 10px; --rs: 6px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;-webkit-tap-highlight-color:transparent;user-select:none}
button{cursor:pointer;border:none;outline:none;font-family:inherit;background:transparent}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--card2);border-radius:2px}

.screen{position:absolute;inset:0;display:none;flex-direction:column;overflow:hidden}
.screen.active{display:flex}

/* TITLE */
#screen-title{align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 25%,#0f2250 0%,var(--bg) 68%);gap:0;padding:2rem;text-align:center}
#screen-title::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 15% 85%,rgba(245,200,66,.04) 0%,transparent 50%),radial-gradient(circle at 85% 15%,rgba(52,152,219,.05) 0%,transparent 50%)}
.title-badge{position:relative;font-family:'Cinzel',serif;font-size:clamp(.55rem,1.8vw,.72rem);letter-spacing:.32em;color:var(--gold);opacity:.75;text-transform:uppercase;margin-bottom:1.4rem}
.title-main{position:relative;font-family:'Cinzel',serif;font-size:clamp(2.4rem,10vw,5.5rem);font-weight:900;line-height:1;color:var(--gold);text-shadow:0 0 60px rgba(245,200,66,.4),0 4px 24px rgba(0,0,0,.85);margin-bottom:.25rem;animation:titlePulse 3.5s ease-in-out infinite alternate}
@keyframes titlePulse{from{text-shadow:0 0 30px rgba(245,200,66,.3),0 4px 24px rgba(0,0,0,.85)}to{text-shadow:0 0 90px rgba(245,200,66,.65),0 4px 24px rgba(0,0,0,.85)}}
.title-sub{position:relative;font-size:clamp(.85rem,2.8vw,1.15rem);color:var(--text2);font-weight:300;letter-spacing:.12em;margin-bottom:.6rem}
.title-desc{position:relative;font-size:clamp(.72rem,1.8vw,.88rem);color:var(--text3);max-width:440px;line-height:1.6;margin-bottom:2.2rem}
.mode-cards{position:relative;display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.mode-card{background:var(--card);border:2px solid var(--border);border-radius:var(--r);padding:1.2rem 1.6rem;width:clamp(170px,36vw,240px);cursor:pointer;transition:all .22s ease}
.mode-card:hover,.mode-card.selected{border-color:var(--gold);background:var(--card2);transform:translateY(-4px);box-shadow:0 10px 36px rgba(245,200,66,.2)}
.mode-card-title{font-size:.9rem;font-weight:700;color:var(--gold);margin-bottom:.35rem}
.mode-card-desc{font-size:.72rem;color:var(--text2);line-height:1.5}
.title-actions{position:relative}
.btn-primary{background:linear-gradient(135deg,var(--gold-dk),var(--gold));color:#000;font-family:'Cinzel',serif;font-size:.95rem;font-weight:700;letter-spacing:.1em;padding:.9rem 2.8rem;border-radius:50px;transition:all .2s;box-shadow:0 8px 28px rgba(245,200,66,.4)}
.btn-primary:hover{transform:scale(1.06);box-shadow:0 12px 36px rgba(245,200,66,.6)}
.btn-primary:active{transform:scale(.97)}

/* PROVINCE SELECT */
#screen-province{background:var(--bg)}
.prov-select-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;gap:8px;flex-wrap:wrap}
.prov-select-header h2{font-family:'Cinzel',serif;color:var(--gold);font-size:clamp(.82rem,2vw,1rem)}
.indicator-tabs{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none}
.indicator-tabs::-webkit-scrollbar{display:none}
.ind-tab{background:var(--card);border:1px solid var(--border);color:var(--text2);padding:4px 10px;border-radius:20px;font-size:.68rem;white-space:nowrap;cursor:pointer;transition:all .18s}
.ind-tab:hover,.ind-tab.active{background:var(--card2);border-color:var(--gold);color:var(--gold)}
.map-wrap{flex:1;min-height:0;overflow:hidden;background:var(--bg2);position:relative}
.prov-grid{height:45vh;max-height:45vh;overflow-y:auto;padding:8px;display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:5px;align-content:start;flex-shrink:0}
@media(min-width:768px){#screen-province{flex-direction:row;flex-wrap:nowrap}.map-wrap{flex:1;max-height:100%}.prov-grid{width:270px;max-width:270px;height:100%;max-height:100%;flex-shrink:0}}
.prov-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rs);padding:8px 10px;cursor:pointer;transition:all .2s}
.prov-card:hover{border-color:var(--gold);background:var(--card2)}
.prov-card-name{font-size:.78rem;font-weight:600;color:var(--text);line-height:1.2}
.prov-card-sub{font-size:.62rem;color:var(--text3);margin-bottom:5px}
.prov-mini-stats{display:flex;flex-direction:column;gap:3px}
.prov-stat-row{display:flex;align-items:center;gap:4px;font-size:.62rem;color:var(--text2)}
.prov-stat-row span:first-child{width:14px;text-align:center}
.prov-stat-bar{flex:1;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.prov-stat-fill{height:100%;border-radius:2px;transition:width .4s ease}
.prov-stat-row span:last-child{width:20px;text-align:right}

/* GAME SCREEN */
#screen-game{background:var(--bg)}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;gap:8px;flex-wrap:wrap}
.topbar-left{display:flex;align-items:center;gap:8px}
.topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.topbar-title{font-family:'Cinzel',serif;font-size:clamp(.78rem,2vw,.95rem);color:var(--gold);white-space:nowrap}
.pop-badge{font-size:.75rem;font-weight:700;color:var(--gold);background:rgba(245,200,66,.1);border:1px solid rgba(245,200,66,.25);padding:3px 10px;border-radius:20px;white-space:nowrap}
.prog-wrap{display:flex;align-items:center;gap:5px}
.prog-bg{width:clamp(60px,12vw,130px);height:5px;background:var(--card2);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--gold-dk),var(--gold));border-radius:3px;transition:width .6s ease}
.prog-lbl{font-size:.65rem;color:var(--text3);white-space:nowrap}
.btn-secondary{background:var(--card);border:1px solid var(--border);color:var(--text2);border-radius:var(--rs);font-size:.72rem;padding:5px 12px;transition:all .18s}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.btn-next{background:linear-gradient(135deg,#1a6e3c,var(--green));color:#fff;font-size:.75rem;font-weight:600;padding:6px 16px;border-radius:50px;white-space:nowrap;box-shadow:0 3px 12px rgba(46,204,113,.35);transition:all .18s}
.btn-next:hover{transform:scale(1.05);box-shadow:0 5px 18px rgba(46,204,113,.5)}
.btn-next:disabled{background:var(--card2);color:var(--text3);box-shadow:none;cursor:not-allowed;transform:none}

.game-tabs{display:flex;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto;scrollbar-width:none}
.game-tabs::-webkit-scrollbar{display:none}
.game-tab{flex:1;min-width:80px;padding:9px 6px;font-size:.72rem;font-weight:500;color:var(--text2);border-bottom:2px solid transparent;text-align:center;cursor:pointer;transition:all .18s;white-space:nowrap}
.game-tab:hover{color:var(--text)}
.game-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:rgba(245,200,66,.05)}

.game-panels{flex:1;min-height:0;position:relative;overflow:hidden}
.game-panel{position:absolute;inset:0;overflow-y:auto;display:none;padding:10px}
.game-panel.active{display:block}

/* DASHBOARD */
.db-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.db-province{flex:1}
.db-prov-name{font-family:'Cinzel',serif;font-size:.92rem;color:var(--gold);line-height:1.2}
.db-prov-sub{font-size:.65rem;color:var(--text3)}
.db-time-badge{font-size:.7rem;color:var(--text2);background:var(--card);padding:3px 10px;border-radius:20px;border:1px solid var(--border);white-space:nowrap}
.db-ipm-badge{display:flex;flex-direction:column;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:var(--rs);padding:4px 10px}
.ipm-val{font-size:1.1rem;font-weight:700;line-height:1}
.ipm-lbl{font-size:.58rem;color:var(--text3);letter-spacing:.08em}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}
@media(min-width:520px){.stats-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rs);padding:8px;transition:border-color .2s}
.stat-card.stat-warn{border-color:rgba(231,76,60,.4)}
.stat-card.stat-good{border-color:rgba(46,204,113,.25)}
.stat-top{display:flex;align-items:center;gap:4px;margin-bottom:5px}
.stat-icon{font-size:.9rem;flex-shrink:0}
.stat-label{flex:1;font-size:.68rem;color:var(--text2)}
.stat-value{font-size:.88rem;font-weight:700;flex-shrink:0}
.stat-bar-bg{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:2px;transition:width .6s ease,background .6s ease}
.budget-row{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:var(--rs);padding:10px 12px}
.budget-icon{font-size:1.2rem}
.budget-label{flex:1;font-size:.78rem;color:var(--text2)}
.budget-value{font-size:1rem;font-weight:700;color:var(--green)}
.budget-danger{color:var(--red)!important}
.budget-rich{color:var(--gold)!important}

/* LOG */
.log-row{padding:6px 10px;margin-bottom:4px;font-size:.75rem;color:var(--text2);background:var(--card);border-radius:4px;border-left:2px solid var(--border);line-height:1.4}
.log-empty{color:var(--text3);font-size:.8rem;text-align:center;padding:2rem}

/* POLICY */
.policy-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.policy-header h3{font-size:.9rem;color:var(--text);flex:1}
.policy-applied-badge{font-size:.68rem;color:var(--green);background:rgba(46,204,113,.12);padding:3px 10px;border-radius:20px;border:1px solid rgba(46,204,113,.25)}
.policy-grid{display:flex;flex-direction:column;gap:6px}
.policy-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rs);padding:10px;display:flex;gap:8px;align-items:flex-start;transition:all .18s}
.policy-card.policy-active:hover{border-color:rgba(245,200,66,.3);background:var(--card2)}
.policy-card.policy-disabled{opacity:.5}
.policy-cat-icon{font-size:1.5rem;flex-shrink:0;width:28px;text-align:center}
.policy-info{flex:1;min-width:0}
.policy-name{font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:2px}
.policy-desc{font-size:.68rem;color:var(--text2);line-height:1.4;margin-bottom:5px}
.policy-footer{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.policy-cost{font-size:.68rem;font-weight:600;color:var(--gold)}
.policy-effects{display:flex;gap:3px;flex-wrap:wrap}
.eff-tag,.eff-sm{font-size:.6rem;padding:1px 5px;border-radius:8px;font-weight:600}
.eff-pos{background:rgba(46,204,113,.18);color:var(--green)}
.eff-neg{background:rgba(231,76,60,.18);color:var(--red)}
.btn-policy{background:linear-gradient(135deg,#1a6e3c,var(--green));color:#fff;font-size:.68rem;font-weight:600;padding:5px 12px;border-radius:20px;flex-shrink:0;align-self:center;transition:all .18s;white-space:nowrap}
.btn-policy:hover{transform:scale(1.04)}
.policy-reason{font-size:.65rem;color:var(--text3);align-self:center;flex-shrink:0;text-align:right;max-width:90px}

/* EVENT MODAL */
.modal-overlay{position:fixed;inset:0;z-index:900;background:rgba(8,14,27,.92);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:1rem}
.modal-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);max-width:480px;width:100%;max-height:92vh;overflow-y:auto;box-shadow:0 20px 64px rgba(0,0,0,.8);animation:modalIn .28s ease}
@keyframes modalIn{from{transform:scale(.88) translateY(24px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.event-modal-box{padding:1.4rem}
.event-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.62rem;font-weight:700;letter-spacing:.1em;margin-bottom:.8rem}
.event-cat{text-transform:uppercase}
.event-title{font-family:'Cinzel',serif;font-size:1.1rem;color:var(--text);margin-bottom:.6rem;line-height:1.3}
.event-desc{font-size:.82rem;color:var(--text2);line-height:1.6;margin-bottom:.8rem}
.event-immediate-effects{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:1rem}
.event-divider{font-size:.75rem;font-weight:600;color:var(--gold);margin-bottom:.6rem;padding-top:.6rem;border-top:1px solid var(--border)}
.event-choices{display:flex;flex-direction:column;gap:6px}
.btn-choice{background:var(--card2);border:1px solid var(--border);border-radius:var(--rs);padding:.8rem 1rem;text-align:left;width:100%;transition:all .18s}
.btn-choice:hover{border-color:var(--gold);background:rgba(245,200,66,.07)}
.choice-label{display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:4px}
.choice-effects{display:flex;flex-wrap:wrap;gap:3px}
.eff-chip{font-size:.65rem;padding:2px 7px;border-radius:8px;font-weight:600;display:inline-block}
.chip-pos{background:rgba(46,204,113,.2);color:var(--green)}
.chip-neg{background:rgba(231,76,60,.2);color:var(--red)}

/* END SCREEN */
#screen-end{background:radial-gradient(ellipse at 50% 5%,#0d1f3a,var(--bg) 70%);align-items:center;justify-content:center;overflow-y:auto}
.end-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;gap:1rem;width:100%}
.end-emoji{font-size:clamp(3rem,10vw,5rem);animation:bounceIn .5s ease}
.end-title{font-family:'Cinzel',serif;font-size:clamp(1.4rem,5vw,2.4rem);animation:bounceIn .6s ease}
.end-reason{font-size:.88rem;color:var(--text2);max-width:420px;line-height:1.6}
.end-stats{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.4rem}
.end-stat{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:70px}
.end-stat span{font-size:.65rem;color:var(--text3)}
.end-stat b{font-size:.95rem;font-weight:700;color:var(--gold)}
@keyframes bounceIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
.hidden{display:none!important}

/* ============================================================
   MAP CENTER + ZOOM SYSTEM
   ============================================================ */

.map-wrap {
  flex: 1;
  min-height: 0;
  overflow: hidden;
  background: radial-gradient(circle at 50% 40%, #0f2250 0%, #08101f 70%);
  position: relative;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* viewport */
.map-viewport {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
  cursor: grab;
}

/* zoom container */
.map-inner {
  width: 100%;
  height: 100%;
  transform-origin: center center;
  transition: transform 0.15s ease-out;
}

/* svg full center */
.map-inner svg {
  width: 100%;
  height: 100%;
}

/* dragging state */
.map-viewport.dragging {
  cursor: grabbing;
}

/* ============================================================
   OVERRIDE LAYOUT — CENTER MAP MODE
   ============================================================ */

@media (min-width:768px){

  #screen-province{
    flex-direction: column !important;
  }

  .prov-grid{
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: 35vh !important;
  }

  .map-wrap{
    max-height: 65vh !important;
  }
}
/* ============================================================
   POLITICAL DASHBOARD  v2
   ============================================================ */

/* HUD Badges */
.hud-badge {
  font-size: .72rem; font-weight: 600;
  padding: 3px 8px; border-radius: 20px;
  border: 1px solid rgba(245,200,66,.2);
  background: rgba(245,200,66,.08);
  color: var(--gold); white-space: nowrap;
  transition: all .3s;
}

/* Layout Politik */
.pol-layout { display: flex; flex-direction: column; gap: 12px; }

.pol-section {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 12px;
}

.pol-section-title {
  font-size: .82rem; font-weight: 700;
  color: var(--text); margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}

.pol-badge {
  font-size: .62rem; font-weight: 700;
  padding: 2px 8px; border-radius: 20px;
  border: 1px solid var(--border);
  background: rgba(245,200,66,.08);
  color: var(--gold);
}
.badge-green { background: rgba(46,204,113,.12); border-color: rgba(46,204,113,.3); color: #2ecc71; }
.badge-red   { background: rgba(231,76,60,.12);  border-color: rgba(231,76,60,.3);  color: #e74c3c; }

/* DPRD Bar */
.dprd-bar {
  display: flex; height: 18px; border-radius: 4px;
  overflow: hidden; gap: 1px; margin-bottom: 6px;
  background: var(--bg3);
}
.dprd-seg { height: 100%; transition: width .4s ease; }
.dprd-legend {
  display: flex; gap: 12px; margin-bottom: 10px;
  font-size: .62rem; color: var(--text2);
}
.leg-item { display: flex; align-items: center; gap: 4px; }
.leg-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }

/* Party Cards */
.party-list { display: flex; flex-direction: column; gap: 6px; }
.party-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--rs); padding: 8px 10px;
  transition: border-color .2s;
}
.party-top { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 6px; }
.party-emoji { font-size: 1.4rem; flex-shrink: 0; }
.party-info { flex: 1; min-width: 0; }
.party-name { display: block; font-size: .78rem; font-weight: 600; color: var(--text); }
.party-desc { display: block; font-size: .63rem; color: var(--text3); line-height: 1.4; margin-top: 1px; }
.party-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; flex-shrink: 0; }
.party-kursi { font-size: .65rem; font-weight: 700; color: var(--gold); }
.party-status { font-size: .6rem; font-weight: 600; white-space: nowrap; }

.loyalty-row { display: flex; align-items: center; gap: 7px; }
.loyalty-lbl { font-size: .6rem; color: var(--text3); flex-shrink: 0; width: 50px; }
.loyalty-bar-bg { flex: 1; height: 4px; background: var(--bg3); border-radius: 2px; overflow: hidden; }
.loyalty-bar-fill { height: 100%; border-radius: 2px; transition: width .5s ease, background .5s ease; }
.loyalty-val { font-size: .65rem; font-weight: 700; flex-shrink: 0; width: 24px; text-align: right; }

/* Sentimen Bar */
.sentimen-bar-wrap {
  display: flex; align-items: center; gap: 8px; margin-bottom: 10px;
}
.sent-lbl-neg, .sent-lbl-pos {
  font-size: .62rem; color: var(--text3); flex-shrink: 0; white-space: nowrap;
}
.sentimen-bg {
  flex: 1; height: 8px; background: var(--bg3);
  border-radius: 4px; overflow: hidden; position: relative;
}
.sentimen-fill {
  height: 100%; border-radius: 4px;
  transition: width .6s ease, background .6s ease;
}
.sentimen-midline {
  position: absolute; top: 0; bottom: 0; left: 50%;
  width: 1px; background: rgba(255,255,255,.2);
}

/* Headlines */
.headlines-list { display: flex; flex-direction: column; gap: 5px; }
.headline-row {
  padding: 6px 10px; background: var(--bg2);
  border-radius: 4px; border-left: 2px solid var(--border);
}
.headline-outlet {
  display: block; font-size: .6rem; color: var(--text3);
  margin-bottom: 2px; font-weight: 600; text-transform: uppercase; letter-spacing: .05em;
}
.headline-teks { font-size: .75rem; color: var(--text); line-height: 1.4; }
.no-news { font-size: .75rem; color: var(--text3); text-align: center; padding: 1rem; }

/* Leaderboard */
.leaderboard { display: flex; flex-direction: column; gap: 5px; margin-bottom: 10px; }
.lb-row {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--rs); padding: 8px 10px; transition: all .2s;
}
.lb-player {
  background: rgba(245,200,66,.08);
  border-color: rgba(245,200,66,.3);
}
.lb-rank { font-size: .8rem; font-weight: 700; color: var(--text3); width: 22px; text-align: center; }
.lb-emoji { font-size: 1.1rem; flex-shrink: 0; }
.lb-info { flex: 1; min-width: 0; }
.lb-nama { display: block; font-size: .77rem; font-weight: 600; color: var(--text); }
.lb-prov { display: block; font-size: .62rem; color: var(--text3); }
.lb-stats { display: flex; align-items: center; gap: 8px; }
.lb-stat { font-size: .68rem; color: var(--text2); white-space: nowrap; }
.lb-score { font-size: .75rem; font-weight: 700; white-space: nowrap; }

/* Rival News */
.rival-news { border-top: 1px solid var(--border); padding-top: 8px; }
.rival-news-title { font-size: .65rem; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 5px; }
.rival-news-item { font-size: .73rem; color: var(--text2); padding: 4px 0; border-bottom: 1px solid rgba(255,255,255,.04); line-height: 1.4; }
.rival-news-item:last-child { border-bottom: none; }

/* Log type: rival */
.log-rival { border-left-color: #9b59b6 !important; }
