/* TenderWatch Pro — Main Stylesheet */
:root {
  --bg:#050A0F; --surface:#0C1520; --surface2:#112035;
  --border:#1A3050; --accent:#00D4FF; --green:#39FF8A;
  --yellow:#FFD700; --red:#FF3B5C; --orange:#FF6B35;
  --text:#E8F4FF; --text2:#7A9BB5; --text3:#4A6A85;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;min-height:100vh}
body::before{content:'';position:fixed;inset:0;
  background:linear-gradient(rgba(0,212,255,.025) 1px,transparent 1px),
             linear-gradient(90deg,rgba(0,212,255,.025) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;z-index:0}

/* HEADER */
header{position:sticky;top:0;z-index:100;height:60px;
  background:rgba(5,10,15,.9);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 28px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),#0080FF);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  font-size:16px;box-shadow:0 0 18px rgba(0,212,255,.4)}
.logo-text{font-family:'Syne',sans-serif;font-weight:800;font-size:18px}
.logo-text span{color:var(--accent)}.logo-text em{font-style:normal;color:var(--text2);font-size:13px}
.logo-badge{background:var(--accent);color:var(--bg);font-size:9px;font-weight:700;
  padding:2px 7px;border-radius:4px;letter-spacing:.5px}
.header-right{display:flex;align-items:center;gap:12px}
.live-pill{display:flex;align-items:center;gap:7px;background:rgba(57,255,138,.1);
  border:1px solid rgba(57,255,138,.3);padding:5px 12px;border-radius:20px;
  font-size:11px;font-weight:600;color:var(--green)}
.live-dot{width:7px;height:7px;background:var(--green);border-radius:50%;
  box-shadow:0 0 8px var(--green);animation:blink 1.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.clock{font-family:'DM Mono',monospace;font-size:11px;color:var(--text3)}
.btn-header{background:var(--surface2);border:1px solid var(--border);
  border-radius:8px;padding:7px 14px;font-size:12px;color:var(--text2);
  text-decoration:none;transition:all .2s}
.btn-header:hover{border-color:var(--accent);color:var(--accent)}

/* TICKER */
.ticker-wrap{background:var(--surface);border-bottom:1px solid var(--border);
  padding:9px 0;overflow:hidden}
.ticker{display:flex;animation:ticker 35s linear infinite;width:max-content}
.tick-item{display:flex;align-items:center;gap:8px;padding:0 28px;
  font-size:12px;white-space:nowrap}
.tick-item b{color:var(--text)}.tick-val{color:var(--yellow);font-family:'DM Mono',monospace}
.tick-sep{color:var(--border)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:22px 28px 0;position:relative;z-index:1}
.stat-card{background:var(--surface);border:1px solid var(--border);
  border-radius:14px;padding:18px 20px;position:relative;overflow:hidden;
  transition:all .3s;cursor:default}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--acc),transparent)}
.stat-card:hover{border-color:var(--acc);transform:translateY(-2px)}
.stat-label{font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.stat-val{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:var(--acc)}
.stat-sub{font-size:11px;color:var(--text3);margin-top:4px}

/* MAIN */
.main-wrap{padding:18px 28px 32px;position:relative;z-index:1}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden}
.panel-head{display:flex;align-items:center;flex-wrap:wrap;gap:10px;
  padding:16px 20px;border-bottom:1px solid var(--border)}
.panel-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;
  display:flex;align-items:center;gap:8px;flex:1}
.panel-badge{background:rgba(0,212,255,.12);border:1px solid rgba(0,212,255,.25);
  color:var(--accent);font-size:10px;padding:2px 8px;border-radius:6px;font-family:'DM Mono',monospace}
.search-wrap input{background:var(--bg);border:1px solid var(--border);border-radius:8px;
  padding:8px 14px;color:var(--text);font-size:13px;width:280px;outline:none;
  font-family:'Inter',sans-serif;transition:border .2s}
.search-wrap input:focus{border-color:var(--accent)}
.search-wrap input::placeholder{color:var(--text3)}
.filter-pills{display:flex;gap:6px;flex-wrap:wrap}
.fpill{background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:6px 13px;font-size:12px;cursor:pointer;color:var(--text2);transition:all .2s;
  font-family:'Inter',sans-serif}
.fpill.active{background:rgba(0,212,255,.12);border-color:var(--accent);color:var(--accent)}
.fpill:hover:not(.active){border-color:var(--text3);color:var(--text)}

/* TABLE */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead tr{background:rgba(0,0,0,.3)}
th{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text3);
  padding:12px 16px;text-align:left;font-weight:600;border-bottom:1px solid var(--border)}
td{padding:13px 16px;border-bottom:1px solid rgba(26,48,80,.4);vertical-align:middle}
tr:hover td{background:rgba(0,212,255,.03)}
tr.hidden{display:none}
.td-name{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:3px}
.td-org{font-size:11px;color:var(--text3)}
.td-hps{font-family:'DM Mono',monospace;font-size:13px;color:var(--yellow);font-weight:500}
.td-kota{font-size:12px;color:var(--text2)}
.td-date{font-size:12px;color:var(--text2);margin-bottom:4px}
.badge-new{display:inline-block;margin-left:8px;background:rgba(57,255,138,.15);
  color:var(--green);font-size:9px;padding:1px 6px;border-radius:10px;font-weight:700}
.days-badge{display:inline-block;font-size:10px;padding:2px 7px;border-radius:5px;font-weight:700}
.days-badge.urgent{background:rgba(255,59,92,.15);color:var(--red)}
.days-badge.soon{background:rgba(255,215,0,.12);color:var(--yellow)}
.days-badge.ok{background:rgba(57,255,138,.1);color:var(--green)}
.status-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;
  border-radius:20px;font-size:11px;font-weight:500}
.status-pill.tayang{background:rgba(57,255,138,.1);border:1px solid rgba(57,255,138,.25);color:var(--green)}
.status-pill.prakualifikasi{background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.25);color:var(--accent)}
.status-pill.evaluasi{background:rgba(255,215,0,.1);border:1px solid rgba(255,215,0,.25);color:var(--yellow)}
.sdot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:blink 1.5s infinite}
.btn-detail{background:var(--surface2);border:1px solid var(--border);border-radius:7px;
  padding:6px 13px;font-size:11px;color:var(--text2);cursor:pointer;
  font-family:'Inter',sans-serif;transition:all .2s}
.btn-detail:hover{border-color:var(--accent);color:var(--accent)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.8);
  backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:18px;
  width:100%;max-width:600px;max-height:85vh;overflow-y:auto;
  transform:translateY(20px);transition:transform .3s}
.modal-overlay.open .modal-box{transform:translateY(0)}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;
  padding:22px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface)}
.modal-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;line-height:1.4}
.modal-close{background:var(--surface2);border:1px solid var(--border);border-radius:7px;
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text2);font-size:14px;transition:all .2s;flex-shrink:0}
.modal-close:hover{border-color:var(--red);color:var(--red)}
.modal-body{padding:22px}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.modal-stat{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:13px}
.ms-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.ms-val{font-family:'Syne',sans-serif;font-size:17px;font-weight:700}
.modal-section{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;color:var(--text2);
  text-transform:uppercase;letter-spacing:1px;margin:18px 0 10px}
.req-item{display:flex;gap:9px;padding:9px 12px;background:var(--surface2);
  border:1px solid var(--border);border-radius:8px;font-size:12px;margin-bottom:6px;line-height:1.5}
.rcheck{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:9px;flex-shrink:0;margin-top:1px}
.rcheck.ok{background:rgba(57,255,138,.15);color:var(--green)}
.rcheck.warn{background:rgba(255,215,0,.12);color:var(--yellow)}
.rcheck.no{background:rgba(255,59,92,.1);color:var(--red)}
.modal-actions{display:flex;gap:8px;margin-top:20px;padding-top:18px;border-top:1px solid var(--border)}
.btn-primary{flex:1;background:linear-gradient(135deg,var(--accent),#0080FF);border:none;
  border-radius:9px;padding:11px;color:var(--bg);font-size:13px;font-weight:700;
  cursor:pointer;font-family:'Inter',sans-serif}
.btn-secondary{background:var(--surface2);border:1px solid var(--border);border-radius:9px;
  padding:11px 16px;color:var(--text);font-size:12px;cursor:pointer;font-family:'Inter',sans-serif}

/* SUBSCRIBER PAGE */
.sub-wrap{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 60px);padding:40px 20px;position:relative;z-index:1}
.sub-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;
  padding:40px;width:100%;max-width:460px;text-align:center}
.sub-icon{font-size:48px;margin-bottom:16px}
.sub-card h1{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;margin-bottom:10px}
.sub-card p{color:var(--text2);font-size:13px;line-height:1.6;margin-bottom:24px}
.sub-form{text-align:left}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px}
.form-group input{width:100%;background:var(--bg);border:1px solid var(--border);
  border-radius:9px;padding:11px 14px;color:var(--text);font-size:13px;outline:none;
  font-family:'Inter',sans-serif;transition:border .2s}
.form-group input:focus{border-color:var(--accent)}
.btn-subscribe{width:100%;background:linear-gradient(135deg,#25D366,#128C7E);border:none;
  border-radius:10px;padding:13px;color:white;font-size:14px;font-weight:700;
  cursor:pointer;font-family:'Inter',sans-serif;box-shadow:0 4px 15px rgba(37,211,102,.25);
  margin-top:8px;transition:all .3s}
.btn-subscribe:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,211,102,.4)}
.sub-note{font-size:11px;color:var(--text3);text-align:center;margin-top:12px;line-height:1.5}
.alert-success{background:rgba(57,255,138,.1);border:1px solid rgba(57,255,138,.3);
  color:var(--green);border-radius:9px;padding:12px;font-size:13px;margin-bottom:16px}
.alert-error{background:rgba(255,59,92,.1);border:1px solid rgba(255,59,92,.3);
  color:var(--red);border-radius:9px;padding:12px;font-size:13px;margin-bottom:16px}

@media(max-width:768px){
  .stats-row{grid-template-columns:1fr 1fr}
  .search-wrap input{width:100%}
  .modal-grid{grid-template-columns:1fr}
}

/* ── PROVINCE CARDS ─────────────────────────────────────── */
.prov-row{display:flex;gap:10px;padding:14px 28px 0;flex-wrap:wrap;position:relative;z-index:1}
.prov-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:12px 16px;cursor:pointer;transition:all .25s;min-width:150px;flex:1}
.prov-card::before{content:'';display:block;width:30px;height:3px;
  background:var(--pc);border-radius:2px;margin-bottom:8px}
.prov-card:hover,.prov-card.active{border-color:var(--pc);background:rgba(0,0,0,.25)}
.prov-card.active{box-shadow:0 0 14px rgba(0,0,0,.3)}
.prov-nama{font-size:11px;color:var(--text2);margin-bottom:4px;font-weight:600}
.prov-val{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--pc)}
.prov-val span{font-size:11px;color:var(--text3);font-family:'Inter',sans-serif;font-weight:400}
.prov-new{font-size:10px;color:var(--green);margin-top:4px}

/* ── TABLE EXTRAS ───────────────────────────────────────── */
.td-num{font-size:11px;color:var(--text3);font-family:'DM Mono',monospace;width:36px}
.td-prov{font-size:10px;color:var(--text3);margin-top:2px}
.btn-lpse{display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;background:var(--surface2);border:1px solid var(--border);
  border-radius:6px;font-size:13px;text-decoration:none;margin-left:4px;
  transition:all .2s;cursor:pointer}
.btn-lpse:hover{border-color:var(--accent)}

/* ── FILTER PILLS KECIL ─────────────────────────────────── */
.fpill-sm{font-size:11px;padding:4px 10px}
.fpill.red.active{background:rgba(255,59,92,.12);border-color:var(--red);color:var(--red)}
.active-kat{background:rgba(139,92,246,.12);border-color:#8B5CF6;color:#8B5CF6}

/* ── EMPTY STATE ────────────────────────────────────────── */
.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-icon{font-size:48px;margin-bottom:12px}
.empty-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;color:var(--text2);margin-bottom:8px}
.empty-sub{font-size:12px;line-height:1.8}
.empty-sub code{background:var(--surface2);padding:2px 6px;border-radius:4px;color:var(--accent)}

/* ── ADMIN ACTIONS ──────────────────────────────────────── */
.btn-action{background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:10px 16px;color:var(--text);font-size:12px;cursor:pointer;
  font-family:'Inter',sans-serif;transition:all .2s}
.btn-action:hover{border-color:var(--accent)}
.btn-action.green{border-color:rgba(57,255,138,.3);color:var(--green)}
.btn-action.green:hover{background:rgba(57,255,138,.1)}
.btn-action.yellow{border-color:rgba(255,215,0,.3);color:var(--yellow)}
.btn-action.yellow:hover{background:rgba(255,215,0,.08)}
.btn-action.blue{border-color:rgba(0,212,255,.3);color:var(--accent)}
.btn-action.blue:hover{background:rgba(0,212,255,.08)}

/* ── MODAL PELUANG ──────────────────────────────────────── */
.peluang-bar-wrap{margin:14px 0}
.peluang-label{font-size:11px;color:var(--text2);margin-bottom:5px;display:flex;justify-content:space-between}
.peluang-bar{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}
.peluang-fill{height:100%;border-radius:4px;transition:width .6s ease}
.peluang-fill.tinggi{background:var(--green)}
.peluang-fill.sedang{background:var(--yellow)}
.peluang-fill.rendah{background:var(--red)}
.peluang-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;margin-bottom:12px}
.peluang-badge.tinggi{background:rgba(57,255,138,.15);color:var(--green);border:1px solid rgba(57,255,138,.3)}
.peluang-badge.sedang{background:rgba(255,215,0,.12);color:var(--yellow);border:1px solid rgba(255,215,0,.3)}
.peluang-badge.rendah{background:rgba(255,59,92,.1);color:var(--red);border:1px solid rgba(255,59,92,.25)}

/* ── TOMBOL SPSE DI TABEL ──────────────────────────────── */
.td-actions{white-space:nowrap;display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.btn-spse{
  display:inline-flex;align-items:center;gap:3px;
  padding:4px 10px;border-radius:5px;font-size:11px;font-weight:700;
  background:linear-gradient(135deg,#0057a8,#00a896);
  color:#fff;text-decoration:none;border:none;cursor:pointer;
  letter-spacing:.4px;transition:opacity .15s,transform .1s;
}
.btn-spse:hover{opacity:.85;transform:translateY(-1px)}
.btn-spse.btn-spse-src{
  background:linear-gradient(135deg,#2d6a4f,#52b788);
}

/* ── SPSE LINK BOX DI MODAL ────────────────────────────── */
.spse-linkbox{
  display:flex;flex-direction:column;gap:8px;
  margin:14px 0 16px;
  background:rgba(0,87,168,.08);
  border:1px solid rgba(0,87,168,.25);
  border-radius:10px;padding:10px;
}
.spse-link-btn{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:8px;
  text-decoration:none;
  background:rgba(0,0,0,.2);
  border:1px solid transparent;
  transition:all .15s;
  color:var(--text1);
}
.spse-link-btn:hover{border-color:rgba(0,168,150,.5);background:rgba(0,168,150,.1)}
.spse-detail:hover{border-color:rgba(0,87,168,.5);background:rgba(0,87,168,.15)}
.spse-link-icon{font-size:18px;flex-shrink:0}
.spse-link-text{flex:1;display:flex;flex-direction:column;gap:1px}
.spse-link-text b{font-size:12px;color:var(--text1);font-weight:600}
.spse-link-text small{font-size:10px;color:var(--text3);word-break:break-all}
.spse-arrow{font-size:14px;color:var(--accent);font-weight:700;flex-shrink:0}

@media(max-width:768px){
  .prov-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px 16px 0}
  .stats-row{grid-template-columns:1fr 1fr}
  .search-wrap input{width:100%}
  .modal-grid{grid-template-columns:1fr}
  .main-wrap{padding:10px 12px 24px}
  header{padding:0 14px}
  .td-actions{flex-direction:column;gap:4px}
}
