/* ============================================================
   TAPMETIC - Complete UI Redesign v2.0
   Brand: Dark OLED  |  Primary: #48b4b8  |  BG: #000000
   ============================================================ */

:root {
  --tmt-primary: #48b4b8;
  --tmt-primary-dark: #3a9599;
  --tmt-primary-glow: rgba(72,180,184,.25);
  --tmt-primary-subtle: rgba(72,180,184,.08);
  --tmt-bg: #000;
  --tmt-card: #111;
  --tmt-card2: #1a1a1a;
  --tmt-border: rgba(72,180,184,.18);
  --tmt-text: #fff;
  --tmt-muted: #888;
  --tmt-red: #ff7b7b;
  --tmt-green: #00b96d;
  --tmt-radius: 12px;
  --tmt-radius-sm: 8px;
  --tmt-t: .2s ease;
}

/* ── GLOBAL ── */
*, *::before, *::after { box-sizing: border-box; }
body { font-family: 'Poppins', sans-serif !important; background: var(--tmt-bg) !important;
       color: var(--tmt-text) !important; -webkit-font-smoothing: antialiased; }
h1,h2,h3,h4,h5,h6 { color: var(--tmt-text) !important; }
p { color: #ccc !important; }
a { color: var(--tmt-primary); }
a:hover { color: var(--tmt-primary-dark); }
.text-muted { color: var(--tmt-muted) !important; }
.text-primary { color: var(--tmt-primary) !important; }
.text-success { color: var(--tmt-green) !important; }
.text-danger  { color: var(--tmt-red) !important; }
.bg-white     { background: #111 !important; }
.bg-light     { background: #1a1a1a !important; }
.bg-primary   { background: var(--tmt-primary) !important; }
.border       { border-color: rgba(255,255,255,.07) !important; }
.border-primary { border-color: var(--tmt-primary) !important; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(72,180,184,.3); border-radius:10px; }
::-webkit-scrollbar-thumb:hover { background:var(--tmt-primary); }

/* ── AUTH PAGE WRAPPER ── */
.tmt-auth-page {
  min-height:100vh; background:#000; display:flex; align-items:center;
  justify-content:center; position:relative; overflow:hidden; padding:24px 16px;
}
.tmt-auth-page::before {
  content:''; position:fixed; inset:0;
  background-image: linear-gradient(rgba(72,180,184,.04) 1px, transparent 1px),
                    linear-gradient(90deg,rgba(72,180,184,.04) 1px, transparent 1px);
  background-size:48px 48px; pointer-events:none; z-index:0;
}
.tmt-glow1 {
  position:fixed; width:520px; height:520px;
  background:radial-gradient(circle,rgba(72,180,184,.14) 0%,transparent 70%);
  top:-180px; right:-100px; pointer-events:none; z-index:0;
  animation:tmt-float 8s ease-in-out infinite;
}
.tmt-glow2 {
  position:fixed; width:420px; height:420px;
  background:radial-gradient(circle,rgba(72,180,184,.09) 0%,transparent 70%);
  bottom:-100px; left:-80px; pointer-events:none; z-index:0;
  animation:tmt-float 11s ease-in-out infinite reverse;
}
@keyframes tmt-float {
  0%,100%{ transform:translateY(0) scale(1); }
  50%{ transform:translateY(-20px) scale(1.04); }
}

/* ── AUTH CARD ── */
.tmt-card {
  background:rgba(14,14,14,.95); border:1px solid var(--tmt-border);
  border-radius:20px; padding:48px 44px; width:100%; max-width:480px;
  position:relative; z-index:1;
  box-shadow: 0 0 0 1px rgba(72,180,184,.06), 0 32px 80px rgba(0,0,0,.7);
  backdrop-filter:blur(20px);
}
.tmt-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--tmt-primary),transparent);
  border-radius:20px 20px 0 0;
}

/* ── AUTH LOGO ── */
.tmt-logo { display:flex; align-items:center; justify-content:center; gap:12px; margin-bottom:32px; }
.tmt-logo img { height:36px; width:auto; }
.tmt-logo span { font-size:22px; font-weight:700; color:#fff; letter-spacing:-.5px; }
.tmt-heading { font-size:26px; font-weight:700; color:#fff !important; text-align:center; margin:0 0 6px; }
.tmt-sub { font-size:14px; color:var(--tmt-muted); text-align:center; margin:0 0 30px; }

/* ── FLASH / ERRORS in auth card ── */
.tmt-card .alert {
  background:rgba(255,123,123,.1) !important; border:1px solid rgba(255,123,123,.3) !important;
  color:#ff9a9a !important; border-radius:var(--tmt-radius-sm) !important;
  font-size:13px; padding:10px 14px; margin-bottom:18px;
}
.tmt-card .alert-success {
  background:rgba(0,185,109,.1) !important; border:1px solid rgba(0,185,109,.3) !important;
  color:#4dd9a0 !important;
}
.tmt-card .text-danger { color:var(--tmt-red) !important; }

/* ── FORM FIELDS (Bootstrap compat inside tmt-card) ── */
.tmt-card .form-control, .tmt-card .form-select {
  background:rgba(255,255,255,.04) !important; border:1px solid rgba(255,255,255,.1) !important;
  border-radius:var(--tmt-radius-sm) !important; color:#fff !important;
  font-family:'Poppins',sans-serif; font-size:14px; padding:11px 16px !important;
  transition:border-color var(--tmt-t), box-shadow var(--tmt-t);
}
.tmt-card .form-control:focus, .tmt-card .form-select:focus {
  border-color:var(--tmt-primary) !important; color:#fff !important;
  box-shadow:0 0 0 3px var(--tmt-primary-glow) !important;
  background:rgba(72,180,184,.04) !important;
}
.tmt-card .form-control::placeholder { color:#555 !important; }
.tmt-card .form-label {
  font-size:13px; font-weight:500; color:#ccc; margin-bottom:7px;
}
.tmt-card .required { color:var(--tmt-primary); }
.tmt-card .form-check-input { accent-color:var(--tmt-primary); }
.tmt-card .form-check-label { font-size:13px; color:#aaa; }
.tmt-card .link-info { color:var(--tmt-primary) !important; }

/* Label row (label + forgot link on same line) */
.tmt-label-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:7px; }
.tmt-label-row label { margin-bottom:0; }
.tmt-forgot { font-size:13px; color:var(--tmt-primary); text-decoration:none; }
.tmt-forgot:hover { text-decoration:underline; }

/* Password toggle */
.tmt-card .input-icon { color:#555 !important; cursor:pointer; }
.tmt-card .input-icon:hover { color:var(--tmt-primary) !important; }

/* Register 2-col row */
.tmt-2col { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* Submit button */
.tmt-card .btn-primary,
.tmt-card .register-btn,
.tmt-card button[type=submit] {
  background:var(--tmt-primary) !important; border-color:var(--tmt-primary) !important;
  color:#fff !important; font-family:'Poppins',sans-serif; font-size:15px;
  font-weight:600; border-radius:var(--tmt-radius-sm) !important;
  padding:12px 24px !important; width:100%; transition:all var(--tmt-t);
  letter-spacing:.2px; cursor:pointer;
}
.tmt-card .btn-primary:hover,
.tmt-card .register-btn:hover,
.tmt-card button[type=submit]:hover {
  background:var(--tmt-primary-dark) !important; border-color:var(--tmt-primary-dark) !important;
  box-shadow:0 4px 20px var(--tmt-primary-glow) !important; transform:translateY(-1px);
}
.tmt-card button[type=submit]:active { transform:translateY(0); }

/* Footer links */
.tmt-auth-foot { text-align:center; font-size:13px; color:var(--tmt-muted); margin-top:24px; }
.tmt-auth-foot a { color:var(--tmt-primary); text-decoration:none; font-weight:500; }
.tmt-auth-foot a:hover { text-decoration:underline; }
.tmt-copyright { text-align:center; font-size:11px; color:#444; margin-top:20px; }
.tmt-copyright a { color:var(--tmt-primary); text-decoration:none; }

/* ── SIDEBAR ── */
.aside-menu-container, #sidebar,
.nav-sidebar, [class*="aside-menu"] {
  background:#050505 !important;
  border-right:1px solid rgba(72,180,184,.1) !important;
}
.aside-menu-container__aside-logo {
  border-bottom:1px solid rgba(72,180,184,.1) !important; padding:18px 20px !important;
}
.sidebar-app-logo { object-fit:contain !important; }
.aside-menu-container .fs-4,
.aside-menu-container span[class*="text"] { color:#fff !important; font-weight:700 !important; }
.aside-menu-container .nav-link,
.aside-menu-container a.nav-link {
  color:var(--tmt-muted) !important; border-radius:var(--tmt-radius-sm) !important;
  transition:all var(--tmt-t) !important;
}
.aside-menu-container .nav-link:hover { color:var(--tmt-primary) !important; background:var(--tmt-primary-subtle) !important; }
.aside-menu-container .nav-link.active { color:var(--tmt-primary) !important; background:var(--tmt-primary-subtle) !important; }
.aside-menu-container .nav-link.active i,
.aside-menu-container .nav-link.active svg { color:var(--tmt-primary) !important; fill:var(--tmt-primary) !important; }
.aside-menu-container__aside-search .form-control,
.aside-menu-container__aside-search input {
  background:rgba(255,255,255,.05) !important;
  border:1px solid rgba(255,255,255,.07) !important; color:#fff !important;
}
.aside-menu-container__aside-search input::placeholder { color:#555 !important; }

/* Sidebar toggle btn */
.aside-menu-container__aside-menubar { color:#888 !important; }
.aside-menu-container__aside-menubar:hover { color:var(--tmt-primary) !important; }

/* ── TOP HEADER / NAVBAR ── */
.page-header, .header, header,
.navbar:not(.tmt-auth-page .navbar) {
  background:#070707 !important; border-bottom:1px solid rgba(72,180,184,.1) !important;
}
.navbar-brand, .header-brand { color:#fff !important; }

/* ── CARDS ── */
.card {
  background:var(--tmt-card) !important; border:1px solid rgba(255,255,255,.05) !important;
  border-radius:var(--tmt-radius) !important; color:var(--tmt-text) !important;
}
.card-header {
  background:transparent !important; border-bottom:1px solid rgba(255,255,255,.05) !important;
  color:var(--tmt-text) !important; font-weight:600;
}
.card-body, .card-footer { color:var(--tmt-text) !important; }
.card-footer { border-top:1px solid rgba(255,255,255,.05) !important; background:transparent !important; }

/* Stat cards teal left-border */
.card.analytics-card,
[class*="stat"],
[class*="counter-card"],
[class*="metric"] {
  border-left:3px solid var(--tmt-primary) !important;
}

/* ── TABLES ── */
.table, .table-responsive table { color:var(--tmt-text) !important; }
.table thead tr th, .table th {
  background:rgba(72,180,184,.07) !important; color:var(--tmt-primary) !important;
  font-size:11px; text-transform:uppercase; letter-spacing:.6px;
  font-weight:600; border-color:rgba(255,255,255,.05) !important;
}
.table td { color:#ccc !important; border-color:rgba(255,255,255,.04) !important; vertical-align:middle; }
.table tbody tr:hover td { background:rgba(72,180,184,.04) !important; color:#fff !important; }
.table-striped>tbody>tr:nth-of-type(odd)>* { background:rgba(255,255,255,.015) !important; color:#ccc !important; }

/* ── BUTTONS ── */
.btn-primary, .btn-info {
  background:var(--tmt-primary) !important; border-color:var(--tmt-primary) !important; color:#fff !important;
}
.btn-primary:hover, .btn-info:hover {
  background:var(--tmt-primary-dark) !important; border-color:var(--tmt-primary-dark) !important;
  box-shadow:0 4px 16px var(--tmt-primary-glow) !important;
}
.btn-outline-primary { border-color:var(--tmt-primary) !important; color:var(--tmt-primary) !important; }
.btn-outline-primary:hover { background:var(--tmt-primary) !important; color:#fff !important; }
.btn-secondary { background:#2a2a2a !important; border-color:#333 !important; color:#ccc !important; }
.btn-danger  { background:var(--tmt-red)   !important; border-color:var(--tmt-red)   !important; }
.btn-success { background:var(--tmt-green) !important; border-color:var(--tmt-green) !important; }

/* ── BADGES ── */
.badge.bg-primary,.badge.bg-info { background:var(--tmt-primary) !important; color:#fff !important; }
.badge.bg-success { background:rgba(0,185,109,.15) !important; color:var(--tmt-green) !important; border:1px solid rgba(0,185,109,.3) !important; }
.badge.bg-danger  { background:rgba(255,123,123,.15) !important; color:var(--tmt-red) !important; border:1px solid rgba(255,123,123,.3) !important; }
.badge.bg-warning { background:rgba(255,184,33,.15) !important; color:#ffb821 !important; border:1px solid rgba(255,184,33,.3) !important; }
.badge.bg-secondary { background:rgba(255,255,255,.08) !important; color:#aaa !important; }

/* ── FORM CONTROLS (dashboard) ── */
.form-control, .form-select {
  background:rgba(255,255,255,.04) !important; border:1px solid rgba(255,255,255,.1) !important;
  color:#fff !important; border-radius:var(--tmt-radius-sm) !important;
  transition:all var(--tmt-t);
}
.form-control:focus, .form-select:focus {
  border-color:var(--tmt-primary) !important; box-shadow:0 0 0 3px var(--tmt-primary-glow) !important;
  background:rgba(72,180,184,.04) !important; color:#fff !important;
}
.form-control::placeholder { color:#555 !important; }
.form-label { color:#aaa !important; font-size:13px; font-weight:500; }
.form-select option { background:#1a1a1a; color:#fff; }
.input-group-text { background:rgba(255,255,255,.04) !important; border-color:rgba(255,255,255,.1) !important; color:#888 !important; }

/* ── DROPDOWNS ── */
.dropdown-menu {
  background:#111 !important; border:1px solid rgba(72,180,184,.15) !important;
  box-shadow:0 8px 32px rgba(0,0,0,.6) !important; border-radius:var(--tmt-radius-sm) !important;
}
.dropdown-item { color:#ccc !important; }
.dropdown-item:hover { background:var(--tmt-primary-subtle) !important; color:var(--tmt-primary) !important; }
.dropdown-divider { border-color:rgba(255,255,255,.06) !important; }
.dropdown-header { color:var(--tmt-muted) !important; font-size:11px; text-transform:uppercase; letter-spacing:.6px; }

/* ── MODALS ── */
.modal-content {
  background:#111 !important; border:1px solid rgba(72,180,184,.15) !important;
  color:var(--tmt-text) !important; border-radius:var(--tmt-radius) !important;
}
.modal-header { border-bottom:1px solid rgba(255,255,255,.06) !important; }
.modal-footer { border-top:1px solid rgba(255,255,255,.06) !important; }
.modal-title { color:var(--tmt-text) !important; font-weight:600 !important; }
.btn-close { filter:invert(1) !important; opacity:.5 !important; }
.btn-close:hover { opacity:1 !important; }

/* ── ALERTS ── */
.alert-primary,.alert-info { background:rgba(72,180,184,.1) !important; border-color:rgba(72,180,184,.3) !important; color:var(--tmt-primary) !important; }
.alert-success { background:rgba(0,185,109,.1) !important; border-color:rgba(0,185,109,.3) !important; color:#4dd9a0 !important; }
.alert-danger  { background:rgba(255,123,123,.1) !important; border-color:rgba(255,123,123,.3) !important; color:#ff9a9a !important; }
.alert-warning { background:rgba(255,184,33,.1) !important; border-color:rgba(255,184,33,.3) !important; color:#ffb821 !important; }

/* ── PAGINATION ── */
.pagination .page-link { background:var(--tmt-card2) !important; border-color:rgba(255,255,255,.08) !important; color:#aaa !important; }
.pagination .page-link:hover { background:var(--tmt-primary-subtle) !important; color:var(--tmt-primary) !important; border-color:var(--tmt-border) !important; }
.pagination .active .page-link { background:var(--tmt-primary) !important; border-color:var(--tmt-primary) !important; color:#fff !important; }

/* ── NAV TABS ── */
.nav-tabs .nav-link { color:var(--tmt-muted) !important; border-color:transparent !important; }
.nav-tabs .nav-link.active,.nav-tabs .nav-link:hover { color:var(--tmt-primary) !important; border-bottom-color:var(--tmt-primary) !important; background:transparent !important; }
.nav-tabs { border-bottom-color:rgba(255,255,255,.08) !important; }

/* ── PROGRESS ── */
.progress { background:rgba(255,255,255,.06) !important; }
.progress-bar { background:var(--tmt-primary) !important; }

/* ── LIST GROUP ── */
.list-group-item { background:var(--tmt-card) !important; border-color:rgba(255,255,255,.05) !important; color:var(--tmt-text) !important; }
.list-group-item:hover { background:rgba(72,180,184,.05) !important; }
.list-group-item.active { background:var(--tmt-primary) !important; border-color:var(--tmt-primary) !important; }

/* ── BREADCRUMB ── */
.breadcrumb-item { color:var(--tmt-muted) !important; }
.breadcrumb-item.active { color:var(--tmt-primary) !important; }
.breadcrumb-item+.breadcrumb-item::before { color:#444 !important; }
.breadcrumb-item a { color:var(--tmt-muted) !important; text-decoration:none; }
.breadcrumb-item a:hover { color:var(--tmt-primary) !important; }

/* ── DATATABLES ── */
.dataTables_filter input,.dataTables_length select {
  background:rgba(255,255,255,.04) !important; border:1px solid rgba(255,255,255,.1) !important;
  color:#fff !important; border-radius:6px !important;
}
.dataTables_info,.dataTables_filter label,.dataTables_length label { color:#888 !important; }
.dataTables_paginate .paginate_button { color:#aaa !important; }
.dataTables_paginate .paginate_button.current { background:var(--tmt-primary) !important; color:#fff !important; border-color:var(--tmt-primary) !important; }

/* ── TOASTS & NOTIFICATIONS ── */
.toast { background:#111 !important; border:1px solid rgba(72,180,184,.2) !important; color:#fff !important; }
.toast-header { background:transparent !important; border-bottom:1px solid rgba(255,255,255,.06) !important; color:#fff !important; }

/* ── OFFCANVAS ── */
.offcanvas { background:#111 !important; border-color:rgba(72,180,184,.15) !important; color:#fff !important; }
.offcanvas-header { border-bottom:1px solid rgba(255,255,255,.06) !important; }
.offcanvas-title { color:#fff !important; }

/* ── ACCORDION ── */
.accordion-item { background:var(--tmt-card) !important; border-color:rgba(255,255,255,.06) !important; }
.accordion-button { background:var(--tmt-card2) !important; color:var(--tmt-text) !important; box-shadow:none !important; }
.accordion-button:not(.collapsed) { background:var(--tmt-primary-subtle) !important; color:var(--tmt-primary) !important; }
.accordion-body { color:#ccc !important; }

/* ── CHARTS ── */
canvas { border-radius:8px; }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .tmt-card { padding:32px 24px; }
  .tmt-2col { grid-template-columns:1fr; }
}


/* ============================================================
   FIX: Remove black focus outlines (replace with teal glow)
   ============================================================ */
*, *:focus, *:focus-visible, *:focus-within,
button:focus, a:focus, input:focus, select:focus,
textarea:focus, [tabindex]:focus,
.btn:focus, .btn:focus-visible,
.btn-close:focus,
.form-control:focus,
.nav-link:focus,
.dropdown-item:focus,
.page-link:focus,
.form-check-input:focus {
  outline: none !important;
  box-shadow: none !important;
}

/* Re-add accessible teal focus ONLY for keyboard nav (not mouse click) */
*:focus-visible {
  outline: 2px solid rgba(72,180,184,.7) !important;
  outline-offset: 2px !important;
  box-shadow: 0 0 0 3px rgba(72,180,184,.15) !important;
}

/* Override Bootstrap's default blue focus ring on form controls */
.form-control:focus, .form-select:focus {
  outline: none !important;
  border-color: var(--tmt-primary) !important;
  box-shadow: 0 0 0 3px var(--tmt-primary-glow) !important;
}

/* Fix btn-close — don't invert non-modal close buttons accidentally */
.btn-close {
  filter: brightness(0) invert(1) !important;
  opacity: .5 !important;
  outline: none !important;
}
.btn-close:hover { opacity: .9 !important; }
.btn-close:focus { box-shadow: 0 0 0 2px rgba(72,180,184,.4) !important; outline:none !important; }

/* Fix anchor/button black rings */
a, button, [role="button"] {
  outline: none !important;
}
a:focus-visible, button:focus-visible, [role="button"]:focus-visible {
  outline: 2px solid rgba(72,180,184,.6) !important;
  outline-offset: 2px !important;
}

/* Sidebar links no black ring */
.aside-menu-container a:focus,
.aside-menu-container a:active,
.nav-link:focus, .nav-link:active {
  outline: none !important;
  box-shadow: none !important;
}

/* Table rows, list items, cards no black ring */
.list-group-item:focus, .list-group-item:active,
.card:focus, .dropdown-item:active {
  outline: none !important;
  box-shadow: none !important;
}

/* ============================================================
   AUTH PAGE — PARTICLE CANVAS BACKGROUND
   ============================================================ */
#tmt-particles {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* Remove old CSS pseudo-element grid (canvas replaces it) */
.tmt-auth-page::before { display: none; }

/* ============================================================
   AUTH PAGE — LOGO ANIMATION
   ============================================================ */
.tmt-logo {
  animation: tmt-logo-drop .7s cubic-bezier(.34,1.56,.64,1) both;
  animation-delay: .1s;
}
@keyframes tmt-logo-drop {
  0%   { opacity:0; transform: translateY(-18px) scale(.85); }
  100% { opacity:1; transform: translateY(0) scale(1); }
}
.tmt-logo img {
  filter: drop-shadow(0 0 10px rgba(72,180,184,.5));
  transition: filter .3s ease;
}
.tmt-logo img:hover {
  filter: drop-shadow(0 0 18px rgba(72,180,184,.9));
}

/* Card entrance animation */
.tmt-card {
  animation: tmt-card-in .55s cubic-bezier(.22,1,.36,1) both;
  animation-delay: .05s;
}
@keyframes tmt-card-in {
  0%   { opacity:0; transform: translateY(28px) scale(.97); }
  100% { opacity:1; transform: translateY(0) scale(1); }
}

/* Heading entrance */
.tmt-heading {
  animation: tmt-fade-up .5s ease both;
  animation-delay: .2s;
}
.tmt-sub {
  animation: tmt-fade-up .5s ease both;
  animation-delay: .28s;
}
@keyframes tmt-fade-up {
  0%   { opacity:0; transform:translateY(10px); }
  100% { opacity:1; transform:translateY(0); }
}

/* Form fields stagger in */
.tmt-card form > * {
  animation: tmt-fade-up .45s ease both;
}
.tmt-card form > *:nth-child(1) { animation-delay:.32s; }
.tmt-card form > *:nth-child(2) { animation-delay:.38s; }
.tmt-card form > *:nth-child(3) { animation-delay:.43s; }
.tmt-card form > *:nth-child(4) { animation-delay:.47s; }
.tmt-card form > *:nth-child(5) { animation-delay:.50s; }
.tmt-card form > *:nth-child(6) { animation-delay:.53s; }

/* ── HARD OVERRIDES: auth page truly full-screen ── */
.tmt-auth-page {
  position: fixed !important;
  inset: 0 !important;
  min-height: 100vh !important;
  width: 100vw !important;
  overflow-y: auto !important;
  z-index: 10 !important;
}
/* Canvas fills the viewport */
#tmt-particles {
  position: fixed !important;
  top:0; left:0; right:0; bottom:0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 0 !important;
  pointer-events: none !important;
}
/* Card sits above canvas */
.tmt-card { position: relative; z-index: 2 !important; }
.tmt-glow1, .tmt-glow2 { z-index: 1 !important; }

/* ════════════════════════════════
   LUXURY PRELOADER
════════════════════════════════ */
#tmt-preloader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: #000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: opacity .7s cubic-bezier(.4,0,.2,1), visibility .7s;
}
#tmt-preloader.tmt-loaded {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* Logo */
.tmt-preloader-logo {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 40px;
  animation: pre-logo-in .8s cubic-bezier(.34,1.56,.64,1) both;
}
.tmt-preloader-logo img {
  height: 52px;
  width: auto;
  filter: drop-shadow(0 0 18px rgba(72,180,184,.8));
  animation: pre-logo-glow 2.5s ease-in-out infinite;
}
.tmt-preloader-logo span {
  font-family: 'Poppins', sans-serif;
  font-size: 30px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -.5px;
}
@keyframes pre-logo-in {
  0%   { opacity:0; transform:scale(.6) translateY(30px); }
  100% { opacity:1; transform:scale(1)  translateY(0); }
}
@keyframes pre-logo-glow {
  0%,100% { filter: drop-shadow(0 0 10px rgba(72,180,184,.5)); }
  50%     { filter: drop-shadow(0 0 28px rgba(72,180,184,1)) drop-shadow(0 0 50px rgba(72,180,184,.4)); }
}


/* Label */
.tmt-preloader-label {
  font-family: 'Poppins', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(72,180,184,.6);
  animation: pre-label-in .6s ease both;
  animation-delay: .4s;
}
@keyframes pre-label-in {
  0%   { opacity:0; transform:translateY(8px); }
  100% { opacity:1; transform:translateY(0); }
}

/* Dot row */
.tmt-preloader-dots {
  display: flex;
  gap: 8px;
  margin-top: 20px;
  animation: pre-label-in .6s ease both;
  animation-delay: .5s;
}
.tmt-preloader-dots span {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--tmt-primary);
}
.tmt-preloader-dots span:nth-child(1) { animation: tmt-dot-pulse 1.1s ease-in-out infinite; }
.tmt-preloader-dots span:nth-child(2) { animation: tmt-dot-pulse 1.1s ease-in-out .18s infinite; }
.tmt-preloader-dots span:nth-child(3) { animation: tmt-dot-pulse 1.1s ease-in-out .36s infinite; }
@keyframes tmt-dot-pulse {
  0%,100% { opacity:.2; transform:scale(.7) translateY(0); }
  50%     { opacity:1;  transform:scale(1.3) translateY(-3px); }
}

/* ── Preloader line (replaces ring) ── */
.tmt-preloader-line{width:220px;height:2px;background:rgba(72,180,184,.12);border-radius:99px;overflow:hidden;margin-bottom:24px;position:relative}
.tmt-preloader-line-fill{position:absolute;top:0;left:0;height:100%;width:45%;background:linear-gradient(90deg,transparent,#48b4b8,#a8ecee,#48b4b8,transparent);animation:tmt-line-slide 1.6s cubic-bezier(.4,0,.2,1) infinite}
@keyframes tmt-line-slide{0%{transform:translateX(-220px)}100%{transform:translateX(440px)}}

/* ── OTP input focus ── */
.tmt-otp-input:focus{border-color:#48b4b8!important;box-shadow:0 0 0 3px rgba(72,180,184,.2)!important;outline:none!important}

/* ── Divider ── */
.tmt-divider{display:flex;align-items:center;gap:12px;color:#333;font-size:12px;margin:20px 0}
.tmt-divider::before,.tmt-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.07)}

/* ── MOBILE FIXES ── */
@media(max-width:600px){
  .tmt-auth-page{padding:16px 12px;align-items:flex-start;padding-top:72px}
  .tmt-card{padding:28px 20px;border-radius:16px;max-width:100%!important}
  .tmt-logo span{font-size:18px}
  .tmt-logo img{height:28px}
  .tmt-heading{font-size:20px}
  .tmt-sub{font-size:13px;margin-bottom:22px}
  .tmt-2col{grid-template-columns:1fr!important;gap:0}
  .tmt-2col>div:first-child{margin-bottom:16px}
  .form-control{font-size:15px!important;padding:10px 14px!important}
  .btn{font-size:14px!important;padding:11px 16px!important}
  .tmt-lang-picker{top:10px;right:10px}
  .tmt-lang-picker .btn{padding:5px 10px;font-size:12px}
  .tmt-otp-input{width:40px!important;height:48px!important;font-size:18px!important}
  .tmt-preloader-logo span{font-size:22px}
  .tmt-preloader-logo img{height:38px}
}
@media(max-width:380px){
  .tmt-otp-input{width:36px!important;height:44px!important;font-size:16px!important}
  #otp-box-wrap{gap:6px!important}
}



/* ═══════════════════════════════════════════════════
   NUCLEAR OUTLINE REMOVAL — overrides Bootstrap 5 vars
   ═══════════════════════════════════════════════════ */
:root {
    --bs-focus-ring-width: 0 !important;
    --bs-focus-ring-color: transparent !important;
    --bs-focus-ring-box-shadow: none !important;
    --bs-btn-focus-box-shadow: none !important;
    --bs-form-valid-border-color: #48b4b8 !important;
    --bs-form-invalid-border-color: #ff7b7b !important;
}

/* Kill outline on every single element — using 0 not 'none' for broader compat */
*,
*::before,
*::after {
    outline: 0 !important;
    -webkit-tap-highlight-color: transparent !important;
    -webkit-focus-ring-color: transparent !important;
}

/* Kill on active/focus/click states */
*:focus,
*:active,
*:focus-within,
*:focus-visible {
    outline: 0 !important;
    outline-offset: 0 !important;
    box-shadow: none !important;
}

/* Bootstrap 5 btn focus */
.btn:focus,
.btn:active,
.btn:focus-visible,
.btn-check:checked + .btn,
.btn-check:focus + .btn,
.btn.active,
.btn.show {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Metronic sidebar / menu links */
.menu-link,
.menu-link:focus,
.menu-link:active,
.menu-link:focus-visible,
.menu-link.active,
.menu-link.here {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Nav / sidebar items */
.nav-link:focus,
.nav-link:active,
.nav-link:focus-visible,
.aside-menu-container a:focus,
.aside-menu-container a:active,
.aside-menu-container a:focus-visible,
[class*="aside"] a:focus,
[class*="aside"] a:active,
[class*="menu"] a:focus,
[class*="menu"] a:active,
[class*="sidebar"] a:focus,
[class*="sidebar"] a:active {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Dropdown items */
.dropdown-item:focus,
.dropdown-item:active,
.dropdown-item:focus-visible {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Table rows/cells */
table tr:focus,
table td:focus,
table th:focus,
tr:focus, td:focus, th:focus {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Form controls — teal focus only */
.form-control:focus,
.form-select:focus,
input:focus,
textarea:focus,
select:focus {
    outline: 0 !important;
    border-color: #48b4b8 !important;
    box-shadow: 0 0 0 3px rgba(72,180,184,.2) !important;
}

/* Select2 */
.select2-container--bootstrap-5 .select2-selection:focus,
.select2-container--bootstrap-5.select2-container--focus .select2-selection {
    outline: 0 !important;
    box-shadow: none !important;
    border-color: #48b4b8 !important;
}

/* Card / list group */
.card:focus, .card:active,
.list-group-item:focus, .list-group-item:active {
    outline: 0 !important;
    box-shadow: none !important;
}

/* Livewire / datatable rows */
[wire\:click]:focus,
[wire\:click]:active,
[data-bs-toggle]:focus,
[data-bs-toggle]:active,
[data-bs-dismiss]:focus,
[data-bs-dismiss]:active {
    outline: 0 !important;
    box-shadow: none !important;
}

/* ═══════════════════════════════════════════════════════
   SIDEBAR ICON CONTAINERS — transparent bg & border
   ═══════════════════════════════════════════════════════ */

/* Target every possible icon wrapper inside sidebar nav links */
.aside-menu-container .nav-link span,
.aside-menu-container .nav-link div,
.aside-menu-container .nav-link i,
.aside-menu-container .nav-link svg,
.aside-menu-container .nav-link img,
.aside-menu-container a span,
.aside-menu-container a div,
.aside-menu-container a i,
[class*="menu-icon"],
[class*="menu_icon"],
[class*="nav-icon"],
.menu-icon,
.menu-icon span,
.menu-icon i,
.menu-icon div,
.aside-menu-container [class*="symbol"],
.aside-menu-container [class*="icon"],
.aside-menu-container [class*="avatar"],
.aside-menu-container [class*="thumb"],
.aside-menu-container [class*="circle"],
.aside-menu-container [class*="bullet"] {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Also target icon wrappers by shape — rounded/circle divs inside sidebar */
.aside-menu-container .rounded,
.aside-menu-container .rounded-circle,
.aside-menu-container .rounded-sm,
.aside-menu-container [style*="border-radius"],
#sidebar .rounded,
#sidebar .rounded-circle,
#sidebar [style*="border-radius"] {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* The icon anchor tags themselves on hover/active */
.aside-menu-container a:hover span,
.aside-menu-container a:active span,
.aside-menu-container a:focus span,
.aside-menu-container a.active span,
.aside-menu-container a:hover div,
.aside-menu-container a:active div,
.aside-menu-container a.active div {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* CircleAvatar equivalent — any div/span used as icon container */
.aside-menu-container .nav-link > span:first-child,
.aside-menu-container .nav-link > div:first-child,
#sidebar .nav-link > span,
#sidebar .nav-link > div {
    background: transparent !important;
    background-color: transparent !important;
    border: transparent !important;
    box-shadow: none !important;
}

/* ── SELECT / DROPDOWN BOXES: solid #495057 background (requested 2026-06-10) ──
   Uses background-color only (preserves the caret), scoped to <select>.form-select
   so text inputs (.form-control) are unaffected. */
.form-select { background-color:#495057 !important; }
.form-select option { background-color:#495057 !important; color:#fff !important; }
