/* ======================================================
   NUMER – NOWOCZESNA STRONA NUMERU TELEFONU v2
   PATH: /public_html/app/portal/css/numer.css
   Wzorowane na firma.css
====================================================== */

/* ===== HERO SECTION ===== */

.num-hero-wrap{
  background:#f8f7fc;
  border-bottom:1px solid #e9e6f5;
  padding:20px 0;
}

.num-hero-inner{
  display:flex;
  align-items:center;
  gap:20px;
}

.num-hero-avatar{
  flex-shrink:0;
}

.num-hero-avatar img{
  width:110px;
  height:110px;
  border-radius:16px;
  background:#fff;
  box-shadow:0 2px 12px rgba(59,47,127,.08);
  object-fit:contain;
  padding:6px;
}

.num-hero-info{
  flex:1;
  min-width:0;
}

.num-hero-variants{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:12px;
}

.num-variant-tag{
  display:inline-flex;
  align-items:center;
  padding:5px 14px;
  background:rgba(59,47,127,.08);
  color:#3b2f7f;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
}

.num-hero-operator{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  color:#555;
  margin-bottom:12px;
}

.num-hero-operator svg{
  opacity:.6;
}

.num-hero-stats{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
}

.num-stat{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.num-stat-val{
  font-size:22px;
  font-weight:800;
  color:#3b2f7f;
  line-height:1.1;
}

.num-stat-label{
  font-size:12px;
  color:#888;
  font-weight:600;
  margin-top:2px;
}

/* ===== MAIN GRID ===== */

.num-wrapper{
  padding-top:20px;
  padding-bottom:32px;
}

.num-main-grid{
  display:grid;
  grid-template-columns:1fr 320px;
  gap:20px;
  align-items:start;
}

/* ===== CARDS ===== */

.num-card{
  background:#fff;
  border-radius:14px;
  padding:20px;
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  border:1px solid rgba(59,47,127,.12);
  transition:box-shadow .2s;
}
.num-card:hover{
  box-shadow:0 4px 16px rgba(59,47,127,.1);
}

/* ===== TABS ===== */

.num-tabs{
  display:flex;
  gap:4px;
  margin-bottom:16px;
  background:#f5f3fa;
  border-radius:12px;
  padding:4px;
  overflow-x:auto;
}

.num-tab{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 18px;
  border:none;
  background:transparent;
  color:#666;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  border-radius:10px;
  transition:all .2s;
  white-space:nowrap;
}

.num-tab:hover{
  background:rgba(59,47,127,.08);
  color:#3b2f7f;
}

.num-tab.active{
  background:#fff;
  color:#3b2f7f;
  box-shadow:0 2px 8px rgba(59,47,127,.12);
}

.num-tab svg{
  opacity:.6;
}

.num-tab.active svg{
  opacity:1;
}

.num-tab-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  padding:0 6px;
  border-radius:11px;
  background:rgba(59,47,127,.1);
  color:#3b2f7f;
  font-size:11px;
  font-weight:700;
}

/* ===== TAB PANELS ===== */

.num-tab-panel{
  display:none;
  animation:numFadeIn .3s ease;
}

.num-tab-panel.active{
  display:block;
}

@keyframes numFadeIn{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}

/* ===== INFO GRID ===== */

.num-info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.num-info-item{
  padding:12px 16px;
  background:#f8f7fc;
  border-radius:12px;
}

.num-info-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:#888;
  font-weight:700;
  margin-bottom:4px;
}

.num-info-value{
  font-size:15px;
  font-weight:600;
  color:#222;
  word-break:break-word;
}

/* ===== STATUS INLINE ===== */

.num-status-inline{
  display:inline-flex;
  align-items:center;
  padding:3px 10px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
}

.num-status-inline.status-spam{
  background:rgba(211,47,47,.1);
  color:#d32f2f;
}

.num-status-inline.status-niebezpieczny{
  background:rgba(245,124,0,.1);
  color:#e65100;
}

.num-status-inline.status-neutralny{
  background:rgba(158,158,158,.15);
  color:#616161;
}

.num-status-inline.status-bezpieczny{
  background:rgba(46,125,50,.1);
  color:#2e7d32;
}

.num-status-inline.status-nieznany{
  background:rgba(158,158,158,.1);
  color:#888;
}

/* ===== REPUTATION BAR ===== */

.num-reputation-bar{
  display:inline-block;
  width:80px;
  height:8px;
  background:#e9e6f5;
  border-radius:4px;
  overflow:hidden;
  vertical-align:middle;
  margin-right:8px;
}

.num-rep-fill{
  display:block;
  height:100%;
  background:linear-gradient(90deg,#d32f2f,#f57c00,#2e7d32);
  border-radius:4px;
  transition:width .5s ease;
}

.num-rep-val{
  font-size:13px;
  font-weight:700;
  color:#3b2f7f;
}

/* ===== VARIANTS PILLS ===== */

.num-variants-grid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.num-variant-pill{
  display:inline-flex;
  align-items:center;
  padding:6px 14px;
  background:#f5f3fa;
  color:#3b2f7f;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  font-family:monospace;
  letter-spacing:.5px;
}

/* ===== DIVIDER ===== */

.num-divider{
  border:none;
  border-top:1px solid #f0eef5;
  margin:20px 0;
}

/* ===== OPINION SUMMARY ===== */

.num-opinion-summary{
  padding:8px 0;
}

.num-opinion-bar-group{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.num-opinion-bar-row{
  display:flex;
  align-items:center;
  gap:12px;
}

.num-opinion-bar-label{
  width:130px;
  font-size:14px;
  font-weight:600;
  flex-shrink:0;
}

.num-opinion-bar-wrap{
  flex:1;
  height:12px;
  background:#f0eef5;
  border-radius:6px;
  overflow:hidden;
}

.num-opinion-bar{
  display:block;
  height:100%;
  border-radius:6px;
  transition:width .6s ease;
}

.num-opinion-bar-plus{
  background:linear-gradient(90deg,#4caf50,#2e7d32);
}

.num-opinion-bar-minus{
  background:linear-gradient(90deg,#ef5350,#d32f2f);
}

.num-opinion-bar-count{
  font-size:14px;
  font-weight:700;
  min-width:30px;
  text-align:right;
}

/* ===== ADD OPINION ===== */

.num-add-opinion h3{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:18px;
  margin:0 0 8px 0;
}

.num-opinion-hint{
  color:#666;
  font-size:14px;
  margin:0 0 16px 0;
}

.num-opinion-btns{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

/* ===== BUTTONS ===== */

.num-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 22px;
  border:none;
  border-radius:12px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  transition:all .2s;
  text-decoration:none;
  font-family:inherit;
}

.num-btn-primary{
  background:linear-gradient(135deg,#3b2f7f,#5b45c3);
  color:#fff;
}

.num-btn-primary:hover{
  background:linear-gradient(135deg,#2f2559,#4a38a8);
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(59,47,127,.3);
}

.num-btn-success{
  background:linear-gradient(135deg,#2e7d32,#4caf50);
  color:#fff;
}

.num-btn-success:hover{
  background:linear-gradient(135deg,#1b5e20,#388e3c);
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(46,125,50,.3);
}

.num-btn-danger{
  background:linear-gradient(135deg,#c62828,#ef5350);
  color:#fff;
}

.num-btn-danger:hover{
  background:linear-gradient(135deg,#b71c1c,#e53935);
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(198,40,40,.3);
}

.num-btn.voted-plus{
  background:#4caf50 !important;
  pointer-events:none;
}

.num-btn.voted-minus{
  background:#ef5350 !important;
  pointer-events:none;
}

/* ===== CTA SIDEBAR ===== */

.num-sidebar-col{
  display:flex;
  flex-direction:column;
  gap:20px;
  position:sticky;
  top:20px;
}

.num-cta-card{
  border:1px solid rgba(59,47,127,.18);
}

.num-cta-header{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
  padding-bottom:12px;
  border-bottom:1px solid #f0eef5;
  font-size:16px;
}

.num-cta-group{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.num-cta-group .num-btn{
  width:100%;
  justify-content:center;
}

/* ===== STATUS CARD ===== */

.num-card-title{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:16px;
  font-weight:700;
  margin:0 0 14px 0;
  color:#222;
}

.num-safety-meter{
  margin-bottom:14px;
}

.num-safety-bar{
  height:10px;
  background:#e9e6f5;
  border-radius:5px;
  overflow:hidden;
  margin-bottom:6px;
}

.num-safety-fill{
  display:block;
  height:100%;
  border-radius:5px;
  transition:width .6s ease;
}

.num-safety-fill.status-bg-spam{
  background:linear-gradient(90deg,#d32f2f,#ef5350);
}

.num-safety-fill.status-bg-niebezpieczny{
  background:linear-gradient(90deg,#e65100,#f57c00);
}

.num-safety-fill.status-bg-neutralny{
  background:linear-gradient(90deg,#9e9e9e,#bdbdbd);
}

.num-safety-fill.status-bg-bezpieczny{
  background:linear-gradient(90deg,#2e7d32,#66bb6a);
}

.num-safety-fill.status-bg-nieznany{
  background:linear-gradient(90deg,#9e9e9e,#bdbdbd);
}

.num-safety-labels{
  display:flex;
  justify-content:space-between;
  font-size:11px;
  color:#888;
}

.num-safety-desc{
  font-size:13px;
  color:#555;
  line-height:1.5;
  margin:0;
}

/* ===== HLR TAB ===== */

.num-hlr-info{
  font-size:13px;
  color:#666;
  line-height:1.5;
  margin:0 0 16px 0;
}

.num-hlr-empty{
  text-align:center;
  padding:30px 20px;
  color:#aaa;
}

.num-hlr-empty p{
  margin:12px 0 0;
  font-size:14px;
}

.num-hlr-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.num-hlr-status-badge{
  display:inline-flex;
  align-items:center;
  padding:4px 12px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
}

.num-hlr-status-badge.hlr-active{
  background:rgba(46,125,50,.1);
  color:#2e7d32;
}

.num-hlr-status-badge.hlr-inactive{
  background:rgba(211,47,47,.1);
  color:#d32f2f;
}

.num-hlr-status-badge.hlr-unknown{
  background:rgba(158,158,158,.1);
  color:#888;
}

/* ===== RELATED NUMBERS ===== */

.num-related-list{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.num-related-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:8px 12px;
  background:#f8f7fc;
  border-radius:10px;
  text-decoration:none;
  color:#222;
  transition:all .2s;
}

.num-related-item:hover{
  background:#e9e6f5;
  color:#3b2f7f;
}

.num-related-number{
  font-weight:600;
  font-size:14px;
  font-family:monospace;
}

/* ===== BADGES (status) ===== */

.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 12px;
  border-radius:999px;
  font-weight:700;
  font-size:12px;
  white-space:nowrap;
}

.badge.light{
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.25);
}

.badge.badge-sm{
  padding:3px 8px;
  font-size:11px;
}

.badge.status-spam{
  background:rgba(211,47,47,.15);
  color:#d32f2f;
  border:1px solid rgba(211,47,47,.25);
}

.badge.status-niebezpieczny{
  background:rgba(245,124,0,.15);
  color:#e65100;
  border:1px solid rgba(245,124,0,.25);
}

.badge.status-neutralny{
  background:rgba(158,158,158,.15);
  color:#616161;
  border:1px solid rgba(158,158,158,.25);
}

.badge.status-bezpieczny{
  background:rgba(46,125,50,.15);
  color:#2e7d32;
  border:1px solid rgba(46,125,50,.25);
}

.badge.status-nieznany{
  background:rgba(158,158,158,.1);
  color:#888;
  border:1px solid rgba(158,158,158,.2);
}

/* ===== AD BANNER ===== */

.num-ad-banner{
  margin:24px auto;
}

.num-ad-slot{
  border-radius:12px;
  overflow:hidden;
}

.num-ad-placeholder{
  background:#f5f3fa;
  color:#bbb;
  text-align:center;
  padding:18px;
  font-size:12px;
  border-radius:12px;
  border:1px dashed #ddd;
}

/* ===== RESPONSIVE ===== */

@media (max-width:900px){
  .num-main-grid{
    grid-template-columns:1fr;
  }

  .num-sidebar-col{
    position:static;
  }

  .num-hero-avatar img{
    width:80px;
    height:80px;
  }

  .num-tabs{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }

  .num-info-grid,
  .num-hlr-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:550px){
  .num-hero-wrap{
    padding:16px 0;
  }

  .num-hero-inner{
    flex-direction:column;
    text-align:center;
    gap:16px;
  }

  .num-hero-variants{
    justify-content:center;
  }

  .num-hero-operator{
    justify-content:center;
  }

  .num-hero-stats{
    justify-content:center;
  }

  .num-stat-val{
    font-size:18px;
  }

  .num-tab{
    padding:8px 12px;
    font-size:13px;
  }

  .num-opinion-btns{
    flex-direction:column;
  }

  .num-opinion-btns .num-btn{
    width:100%;
  }

  .num-card{
    padding:16px;
    border-radius:12px;
  }
}

/* ===== HLR / OPERATOR EXTENSIONS ===== */

.num-hero-operators{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:12px;
}

.num-hero-operator-hlr{
  color:#2e7d32;
  font-weight:600;
}

.num-hlr-date{
  font-size:12px;
  color:#888;
  font-weight:400;
  margin-left:4px;
}

.num-hlr-age{
  font-size:12px;
  color:#888;
  font-weight:400;
  margin-left:4px;
}

.num-hlr-stale-badge{
  display:inline-block;
  padding:2px 8px;
  background:#fff3cd;
  color:#856404;
  border-radius:6px;
  font-size:11px;
  font-weight:600;
  margin-left:6px;
}

.num-hlr-portowanie-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:6px 12px;
  background:linear-gradient(135deg,#e8f5e9,#f1f8e9);
  color:#2e7d32;
  border-radius:8px;
  font-size:12px;
  font-weight:600;
  border:1px solid rgba(46,125,50,.2);
}

.num-info-item-note{
  grid-column:1 / -1;
}

.num-hlr-status-badge.hlr-active{
  background:#e8f5e9;
  color:#2e7d32;
  padding:3px 10px;
  border-radius:6px;
  font-size:12px;
  font-weight:700;
}

.num-hlr-status-badge.hlr-pending{
  background:#fff3cd;
  color:#856404;
  padding:3px 10px;
  border-radius:6px;
  font-size:12px;
  font-weight:700;
}

.num-hlr-status-badge.hlr-unknown{
  background:#f5f5f5;
  color:#666;
  padding:3px 10px;
  border-radius:6px;
  font-size:12px;
  font-weight:700;
}

.num-hlr-refresh-section{
  margin-top:16px;
  padding-top:16px;
  border-top:1px dashed rgba(59,47,127,.15);
}

.num-hlr-stale-msg{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:#856404;
  margin-bottom:12px;
}

.num-hlr-refresh-btn{
  gap:6px;
}

.num-hlr-refresh-btn svg{
  flex-shrink:0;
}
