/*
Theme Name: twe
Theme URI: https://trafficwe
Description: Unique right-sidebar navigation theme for TrafficWe (Bootstrap 4).
Version: 1.0
Author: Ian Cormier
*/

@charset "utf-8";

@import url("https://fonts.googleapis.com/css2?family=Orbitron:wght@500;700&display=swap");

/* -----------------------------
   100kTraffic • Design Tokens
------------------------------ */
:root{
  --bg0:#050505;
  --bg1:#0b0b0b;
  --bg2:#111111;

  --panel:rgba(255,204,51,.06);
  --panel2:rgba(255,204,51,.10);
  --stroke:rgba(255,204,51,.18);

  --text:#fff7d6;
  --muted:rgba(255,247,214,.72);

  /* Gold-only palette (keep legacy token names for reuse) */
  --cyan:#ffcc33;
  --magenta:#ffb700;
  --lime:#ffe37a;
  --amber:#ffcc33;
  --red:#ffcc33;
  --pink:#ffb700;

  --radius:18px;
  --shadow: 0 18px 50px rgba(0,0,0,.55);

  --focus: 0 0 0 .2rem rgba(255,204,51,.25);
}

/* -----------------------------
   Base / Typography
------------------------------ */
html, body{ height:100%; }
body{
  font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size: 15px;
  color: var(--text);

  /* black + gold glow */
  background:
    radial-gradient(1100px 700px at 12% 12%, rgba(255,204,51,.16) 0%, rgba(255,204,51,0) 55%),
    radial-gradient(900px 650px at 85% 22%, rgba(255,227,122,.12) 0%, rgba(255,227,122,0) 60%),
    radial-gradient(900px 650px at 55% 88%, rgba(255,183,0,.10) 0%, rgba(255,183,0,0) 58%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
  background-attachment: fixed;

  padding-top: 0; /* sidebar layout (no fixed top navbar) */
}



body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,.03) 0px,
      rgba(255,255,255,.03) 1px,
      rgba(0,0,0,0) 3px,
      rgba(0,0,0,0) 6px
    );
  opacity:.22;
  mix-blend-mode: overlay;
}

a{ color: var(--amber); }
a:hover{ color: var(--lime); text-decoration:none; }

h1,h2,h3,h4,h5{ letter-spacing:.2px; }

/* Improve default Bootstrap elements on dark bg */
.container{ position:relative; z-index:1; }
.card, .modal-content{
  background: var(--panel);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.table{
  color: var(--text);
}
.table thead th{
  border-color: rgba(255,255,255,.18);
}
.table td, .table th{
  border-color: rgba(255,255,255,.10);
}

.form-control, .custom-select{
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.14);
  color: var(--text);
  border-radius: 14px;
}
.form-control:focus, .custom-select:focus{
  background: rgba(0,0,0,.28);
  border-color: rgba(255,204,51,.45);
  box-shadow: var(--focus);
  color: var(--text);
}
::placeholder{ color: rgba(242,245,255,.55)!important; }

/* -----------------------------
   Buttons
------------------------------ */
.btn{
  border-radius: 14px;
  font-weight: 600;
  letter-spacing:.2px;
}
.btn:focus{ box-shadow: var(--focus)!important; }

.btn-primary{
  border: 1px solid rgba(255,204,51,.55);
  color:#061018;
  background: linear-gradient(135deg, rgba(255,227,122,1), rgba(255,183,0,1));
}
.btn-primary:hover{
  filter: brightness(1.05);
  transform: translateY(-1px);
}
.btn-secondary{
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.16);
  color: var(--text);
}
.btn-secondary:hover{ background: rgba(255,255,255,.14); }

.btn-success{
  background: linear-gradient(135deg, rgba(255,227,122,1), rgba(255,204,51,1));
  border: 1px solid rgba(255,204,51,.55);
  color:#120f05;
}
.btn-danger{
  background: linear-gradient(135deg, rgba(255,204,51,1), rgba(255,183,0,1));
  border: 1px solid rgba(255,183,0,.65);
  color:#120f05;
}


/* -----------------------------
   100kTraffic • Signature Navbar
------------------------------ */
.nav-100k{
  position: relative;
  border-radius: 0 0 18px 18px;
}
.nav-100k::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:2px;
  background: linear-gradient(90deg, var(--pink), var(--cyan), var(--lime));
  opacity:.85;
}
.nav-100k::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:2px;
  background: linear-gradient(90deg, var(--lime), var(--cyan), var(--pink));
  opacity:.55;
}

.brand-100k{
  font-family: "Orbitron", "Segoe UI", Tahoma, sans-serif;
  font-weight: 700;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: 1.08rem;
  line-height: 1;
  padding: .22rem .45rem;
  border-radius: 14px;

  background: linear-gradient(180deg, #ffe37a, #ffb300);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  text-shadow:
    0 0 18px rgba(255,195,0,.22),
    0 0 2px rgba(0,0,0,.85);
  position: relative;
}
.brand-100k::after{
  content:"";
  position:absolute;
  inset:-8px -14px;
  border-radius: 18px;
  background: linear-gradient(90deg, rgba(255,195,0,.22), rgba(255,61,242,.14), rgba(52,245,255,.12));
  filter: blur(12px);
  z-index:-1;
}

.nav-100k .navbar-toggler{
  border-color: rgba(255,213,74,.35);
}
.nav-100k .navbar-toggler:focus{
  box-shadow: 0 0 0 .2rem rgba(255,213,74,.18);
}
.nav-100k .navbar-toggler-icon{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,213,74,0.95)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.nav-100k .navbar-nav > .nav-item > .nav-link{
  position: relative;
  background: rgba(0,0,0,.12);
  border: 1px solid transparent;
}
.nav-100k .navbar-nav > .nav-item > .nav-link::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: 999px;
  padding:1px;
  background: linear-gradient(135deg, rgba(52,245,255,.55), rgba(255,61,242,.45), rgba(255,213,74,.45));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity:.55;
  pointer-events:none;
}
.nav-100k .navbar-nav > .nav-item > .nav-link:hover::before{ opacity:.95; }
.nav-100k .navbar-nav > .nav-item.lfm_tab_opened > .nav-link{
  color: var(--text);
  background: rgba(255,213,74,.14);
}
.nav-100k .navbar-nav > .nav-item.lfm_tab_opened > .nav-link::before{
  opacity: 1;
}

/* -----------------------------
   LFM • Menu (Bootstrap 4 Navbar)
------------------------------ */
.lfm_menu_bar{
  position: sticky;
  top: 0;
  z-index: 1050;
  border-bottom: 1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(90deg, rgba(255,61,242,.28), rgba(52,245,255,.22), rgba(182,255,61,.18)),
    rgba(10,10,25,.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lfm_menu_bar .navbar{
  padding:.75rem 1rem;
}
.lfm_menu_bar .navbar-brand{
  font-weight: 800;
  letter-spacing:.3px;
}
.lfm_menu_bar .navbar-nav > .nav-item > .nav-link{
  font-size: 14px;
  color: rgba(242,245,255,.92);
  border-radius: 12px;
  padding: .55rem .75rem;
  margin: .1rem .15rem;
}
.lfm_menu_bar .navbar-nav > .nav-item > .nav-link:hover{
  color: var(--text);
  background: rgba(255,255,255,.08);
}
.lfm_menu_bar .navbar-nav > .nav-item.lfm_tab_opened > .nav-link{
  color: #071018;
  background: linear-gradient(135deg, rgba(255,227,122,1), rgba(255,183,0,1));
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
.lfm_menu_bar .dropdown-menu{
  background: rgba(10,10,25,.98);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 16px;
  box-shadow: var(--shadow);
}
.lfm_menu_bar .dropdown-item{
  color: rgba(242,245,255,.88);
  border-radius: 12px;
  padding: .5rem .75rem;
}
.lfm_menu_bar .dropdown-item:hover,
.lfm_menu_bar .dropdown-item:focus{
  color: var(--text);
  background: rgba(255,255,255,.08);
}

/* Mobile tweaks */
@media (max-width: 991.98px){
  .lfm_menu_bar .navbar-toggler{
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 14px;
    padding: .4rem .55rem;
  }
  .lfm_menu_bar .navbar-collapse{
    margin-top: .75rem;
    padding: .75rem;
    border-radius: 18px;
    background: rgba(0,0,0,.22);
    border: 1px solid rgba(255,255,255,.12);
  }
}

/* -----------------------------
   Footer (optional)
------------------------------ */
.lfm_footer{
  margin-top: 3rem;
  padding-top: 2.25rem;
  padding-bottom: 2rem;
  background: rgba(0,0,0,.35);
  border-top: 1px solid rgba(255,255,255,.10);
}
.lfm_footer a{ color: rgba(242,245,255,.86); }
.lfm_footer a:hover{ color: var(--cyan); }

/* -----------------------------
   Icons / Avatars
------------------------------ */
.lfm_icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.lfm_icon i{ color: var(--cyan); }

/* Profile picture sizes (kept from default theme expectations) */
.lfm_profile_pic_sm{ width: 38px; height: 38px; border-radius: 50%; }
.lfm_profile_pic_md{ width: 60px; height: 60px; border-radius: 50%; }
.lfm_profile_pic_lg{ width: 92px; height: 92px; border-radius: 50%; }
.lfm_profile_pic_sm, .lfm_profile_pic_md, .lfm_profile_pic_lg{
  border: 2px solid rgba(255,255,255,.18);
  box-shadow: 0 12px 26px rgba(0,0,0,.35);
}

/* -----------------------------
   Misc / Utility
------------------------------ */
hr{ border-color: rgba(255,255,255,.12); }
.text-muted{ color: var(--muted)!important; }

/* Reduce harsh white cards used by some plugins */
.bg-white{ background-color: rgba(255,255,255,.06)!important; }
.border{ border-color: rgba(255,255,255,.12)!important; }


/* ------------------- 100k NAV DROPDOWNS ------------------- */
.dropdown-menu-100k{
  background: rgba(9, 12, 24, .98);
  border: 1px solid rgba(255, 213, 74, .22);
  box-shadow: 0 0 0 1px rgba(52,245,255,.10), 0 18px 55px rgba(0,0,0,.65);
  border-radius: 14px;
  padding: .55rem;
  min-width: 15rem;
}
.dropdown-menu-100k .dropdown-header{
  color: rgba(255,213,74,.92);
  font-family: "Orbitron", "Segoe UI", Tahoma, sans-serif;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .72rem;
  padding: .45rem .75rem .25rem;
}
.dropdown-menu-100k .dropdown-divider{
  border-top: 1px solid rgba(255,255,255,.08);
  margin: .35rem .25rem;
}
.dropdown-menu-100k .dropdown-item{
  color: rgba(238,242,255,.92);
  border-radius: 12px;
  padding: .55rem .75rem;
}
.dropdown-menu-100k .dropdown-item:hover,
.dropdown-menu-100k .dropdown-item:focus{
  color: #fff;
  background: linear-gradient(90deg, rgba(255,61,242,.18), rgba(52,245,255,.16));
}

/* ---------------------------------
   Unique Layout: Right Sidebar Menu
---------------------------------- */
.layout-100k{ min-height:100vh; }

.main-100k{
  min-height:100vh;
  padding: 18px 0 40px;
  margin-right: 280px; /* room for the fixed sidebar */
}

.sidebar-100k{
  position: fixed;
  top: 0;
  right: 0;
  width: 280px;
  height: 100vh;
  z-index: 1060;
  padding: 16px 14px 18px;
  overflow-y: auto;

  background:
    radial-gradient(900px 600px at 30% 10%, rgba(255,61,242,.14) 0%, rgba(255,61,242,0) 60%),
    radial-gradient(800px 600px at 75% 60%, rgba(52,245,255,.12) 0%, rgba(52,245,255,0) 62%),
    linear-gradient(180deg, rgba(14,16,48,.92), rgba(7,5,20,.94));
  border-left: 1px solid rgba(255,255,255,.12);
  box-shadow: -18px 0 55px rgba(0,0,0,.55);
}

.sidebar-100k::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width: 2px;
  background: linear-gradient(180deg, var(--magenta), var(--cyan), var(--lime));
  opacity:.7;
}

.sidebar-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 6px 14px;
}

.brand-100k{
  font-family: 'Orbitron', system-ui, sans-serif;
  font-weight: 700;
  letter-spacing: .8px;
  font-size: 1.1rem;
  background: linear-gradient(180deg, #ffe9a3, #ffcc4d 45%, #ffb02e);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 0 14px rgba(255,176,46,.18);
}

.sidebar-close{
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.22);
  color: var(--text);
  border-radius: 12px;
  width: 40px;
  height: 40px;
  line-height: 36px;
  font-size: 26px;
}

.sidebar-nav .nav-item{ margin: 6px 4px; }
.sidebar-nav .nav-link{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 11px 12px;
  color: rgba(242,245,255,.90);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.sidebar-nav .nav-link:hover{
  color:#fff;
  border-color: rgba(52,245,255,.35);
  box-shadow: 0 0 0 .2rem rgba(52,245,255,.12);
}
.sidebar-nav .lfm_tab_opened > .nav-link{
  border-color: rgba(255,61,242,.45);
  box-shadow: 0 0 0 .2rem rgba(255,61,242,.10);
}

/* Make dropdown menus behave like in-flow accordion panels inside the sidebar */
.sidebar-100k .dropdown-menu{
  position: static;
  float: none;
  width: auto;
  margin: 8px 6px 10px;
}
.sidebar-100k .dropdown-toggle::after{
  margin-left: auto;
}

/* Mobile: slide-in sidebar + topbar toggle */
.topbar-100k{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1065;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(7,5,20,.82);
  border-bottom: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
}
.topbar-toggle{
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  border-radius: 14px;
  width: 44px;
  height: 40px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.topbar-bars{
  width: 18px;
  height: 2px;
  background: rgba(242,245,255,.92);
  position: relative;
  display:block;
}
.topbar-bars::before,
.topbar-bars::after{
  content:"";
  position:absolute;
  left:0;
  width: 18px;
  height: 2px;
  background: rgba(242,245,255,.92);
}
.topbar-bars::before{ top: -6px; }
.topbar-bars::after{ top: 6px; }

.sidebar-overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  opacity: 0;
  pointer-events: none;
  z-index: 1059;
  transition: opacity .18s ease;
}
.sidebar-overlay.is-open{ opacity: 1; pointer-events:auto; }

@media (max-width: 991.98px){
  body{ padding-top: 62px; }
  .main-100k{ margin-right: 0; }
  .sidebar-100k{
    width: min(340px, 92vw);
    transform: translateX(105%);
    transition: transform .18s ease;
  }
  .sidebar-100k.is-open{ transform: translateX(0); }
}

