/**
 * Initech Theme - Terminal Command Aesthetic
 * Dark mode, monospace typography, sharp edges
 * "Military command meets modern SaaS"
 */

/* ═══════════════════════════════════════════════════════════════════════════
   FONT IMPORTS
   ═══════════════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap');

/* ═══════════════════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES (DESIGN TOKENS)
   ═══════════════════════════════════════════════════════════════════════════ */
:root {
    /* Background Colors */
    --bg-primary: #0a0a0a;
    --bg-secondary: #111111;
    --bg-tertiary: #161616;
    --bg-elevated: #1a1a1a;
    --bg-hover: #1f1f1f;
    --bg-input: #0d0d0d;

    /* Border Colors */
    --border-primary: #222222;
    --border-secondary: #333333;
    --border-hover: #444444;

    /* Text Colors */
    --text-primary: #e5e5e5;
    --text-secondary: #999999;
    --text-muted: #666666;
    --text-disabled: #444444;

    /* Accent Colors - Red Theme */
    --accent-primary: #ff3333;
    --accent-primary-dim: #cc2929;
    --accent-primary-bright: #ff5555;
    --accent-secondary: #ff6b6b;

    /* Legacy mappings for compatibility */
    --accent-green: #ff3333;
    --accent-green-dim: #cc2929;
    --accent-cyan: #ff5555;
    --accent-amber: #ff6b6b;
    --accent-red: #ff3333;
    --accent-red-dim: #cc2929;

    /* Status Colors */
    --status-success: #44cc44;
    --status-warning: #ffaa00;
    --status-error: #ff3333;
    --status-info: #ff5555;

    /* Typography */
    --font-mono: 'JetBrains Mono', 'IBM Plex Mono', 'Fira Code', monospace;
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --spacing-2xl: 48px;

    /* Border Radius - Sharp corners */
    --radius-none: 0;
    --radius-sm: 2px;

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-normal: 250ms ease;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BASE STYLES
   ═══════════════════════════════════════════════════════════════════════════ */
html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-sans);
    font-size: 14px;
    line-height: 1.6;
    color: var(--text-primary);
    background-color: #050505 !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection {
    background: var(--accent-primary);
    color: var(--bg-primary);
}

/* ═══════════════════════════════════════════════════════════════════════════
   PREMIUM HEADER - Lambda/Linear Style
   ═══════════════════════════════════════════════════════════════════════════ */
.initech-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(5, 5, 5, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

/* Topbar for logged in users */
.initech-topbar {
    background: rgba(10, 10, 10, 0.9);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    padding: 8px 0;
}

.initech-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.initech-topbar-left,
.initech-topbar-right {
    display: flex;
    align-items: center;
    gap: 12px;
}

.initech-topbar-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 6px;
    color: #888;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.initech-topbar-btn:hover {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.initech-topbar-btn-admin {
    color: var(--accent-primary);
    border-color: rgba(255, 51, 51, 0.2);
}

.initech-topbar-btn-admin:hover {
    background: rgba(255, 51, 51, 0.1);
    border-color: rgba(255, 51, 51, 0.3);
    color: var(--accent-primary);
}

.initech-notif-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: var(--accent-primary);
    border-radius: 100px;
    font-size: 10px;
    font-weight: 600;
    color: #fff;
}

.initech-topbar-label {
    font-size: 12px;
    color: #555;
}

.initech-topbar-user {
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    text-decoration: none;
    transition: color 0.2s ease;
}

.initech-topbar-user:hover {
    color: var(--accent-primary);
    text-decoration: none;
}

/* Main Navbar */
.initech-navbar {
    padding: 16px 0;
}

.initech-navbar-inner {
    display: flex;
    align-items: center;
    gap: 32px;
}

/* Logo */
.initech-logo {
    display: flex;
    align-items: center;
    text-decoration: none;
    flex-shrink: 0;
}

.initech-logo:hover {
    text-decoration: none;
}

.initech-logo-img {
    height: 28px;
    width: auto;
}

.initech-logo-text {
    display: flex;
    align-items: center;
    gap: 2px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 18px;
    font-weight: 600;
    color: #fff;
    letter-spacing: -0.02em;
}

.initech-logo-symbol {
    color: var(--accent-primary);
    font-weight: 700;
}

/* Navigation */
.initech-nav {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
}

.initech-nav-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 8px 14px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: #888;
    text-decoration: none;
    background: transparent;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.initech-nav-link:hover,
.initech-nav-link.active {
    color: #fff;
    background: rgba(255, 255, 255, 0.04);
    text-decoration: none;
}

.initech-nav-link.active {
    color: var(--accent-primary);
}

.initech-nav-link svg {
    opacity: 0.5;
}

/* Dropdowns */
.initech-nav-dropdown {
    position: relative;
}

.initech-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    padding: 8px;
    background: #0d0d0d;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: all 0.2s ease;
}

.initech-nav-dropdown:hover .initech-dropdown-menu,
.initech-dropdown-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(4px);
}

.initech-dropdown-item {
    display: block;
    padding: 10px 14px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    color: #888;
    text-decoration: none;
    border-radius: 6px;
    transition: all 0.15s ease;
}

.initech-dropdown-item:hover,
.initech-dropdown-item.active {
    color: #fff;
    background: rgba(255, 255, 255, 0.04);
    text-decoration: none;
}

.initech-dropdown-item.active {
    color: var(--accent-primary);
}

/* Navbar Actions */
.initech-navbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: auto;
}

/* Search */
.initech-search {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    transition: all 0.2s ease;
}

.initech-search:focus-within {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 51, 51, 0.3);
    box-shadow: 0 0 0 3px rgba(255, 51, 51, 0.1);
}

.initech-search svg {
    color: #555;
    flex-shrink: 0;
}

.initech-search input {
    width: 160px;
    background: transparent;
    border: none;
    outline: none;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    color: #fff;
}

.initech-search input::placeholder {
    color: #555;
}

/* Cart Button */
.initech-cart-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    color: #888;
    text-decoration: none;
    transition: all 0.2s ease;
}

.initech-cart-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.1);
    color: #fff;
    text-decoration: none;
}

.initech-cart-count {
    position: absolute;
    top: -4px;
    right: -4px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--accent-primary);
    border-radius: 100px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    color: #fff;
}

/* Auth Buttons */
.initech-auth-btns {
    display: flex;
    align-items: center;
    gap: 8px;
}

.initech-btn-ghost {
    display: inline-flex;
    align-items: center;
    padding: 10px 18px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: #888;
    text-decoration: none;
    background: transparent;
    border: 1px solid transparent;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.initech-btn-ghost:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.04);
    text-decoration: none;
}

.initech-header .initech-btn-primary {
    display: inline-flex;
    align-items: center;
    padding: 10px 18px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
    text-decoration: none;
    background: var(--accent-primary);
    border: none;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.initech-header .initech-btn-primary:hover {
    background: var(--accent-primary-dim);
    box-shadow: 0 4px 16px rgba(255, 51, 51, 0.3);
    text-decoration: none;
    color: #fff;
}

/* User Menu */
.initech-user-menu {
    display: flex;
    align-items: center;
}

.initech-user-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.initech-user-btn:hover {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.12);
}

.initech-user-btn svg {
    color: #555;
}

.initech-user-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-primary-dim) 100%);
    border-radius: 6px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    text-transform: uppercase;
}

/* Mobile Toggle */
.initech-mobile-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    color: #888;
    cursor: pointer;
    transition: all 0.2s ease;
}

.initech-mobile-toggle:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
}

/* Mobile Navigation */
.initech-mobile-nav {
    background: #0a0a0a;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding: 20px 0;
}

.initech-mobile-search {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    margin-bottom: 16px;
}

.initech-mobile-search svg {
    color: #555;
    flex-shrink: 0;
}

.initech-mobile-search input {
    width: 100%;
    background: transparent;
    border: none;
    outline: none;
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    color: #fff;
}

.initech-mobile-search input::placeholder {
    color: #555;
}

.initech-mobile-menu {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 16px;
}

.initech-mobile-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    font-weight: 500;
    color: #888;
    text-decoration: none;
    background: transparent;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
    width: 100%;
    text-align: left;
}

.initech-mobile-link:hover,
.initech-mobile-link.active {
    color: #fff;
    background: rgba(255, 255, 255, 0.04);
    text-decoration: none;
}

.initech-mobile-link.active {
    color: var(--accent-primary);
}

.initech-mobile-sublink {
    display: block;
    padding: 10px 16px 10px 32px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    color: #666;
    text-decoration: none;
    transition: all 0.15s ease;
}

.initech-mobile-sublink:hover {
    color: #fff;
    text-decoration: none;
}

.initech-mobile-auth {
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Mobile Auth Top (Login/Register buttons) */
.initech-mobile-auth-top {
    display: flex;
    gap: 12px;
    padding-bottom: 16px;
    margin-bottom: 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.initech-mobile-btn-ghost {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: #888;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    transition: all 0.2s ease;
}

.initech-mobile-btn-ghost:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
    text-decoration: none;
}

.initech-mobile-btn-primary {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
    text-decoration: none;
    background: var(--accent-primary);
    border: none;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.initech-mobile-btn-primary:hover {
    background: var(--accent-primary-dim);
    text-decoration: none;
    color: #fff;
}

/* Breadcrumb */
.initech-breadcrumb {
    background: rgba(5, 5, 5, 0.95);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    padding: 12px 0;
}

.initech-breadcrumb .breadcrumb {
    background: transparent;
    margin: 0;
    padding: 0;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
}

.initech-breadcrumb .breadcrumb-item,
.initech-breadcrumb .breadcrumb-item a {
    color: #555;
    text-decoration: none;
}

.initech-breadcrumb .breadcrumb-item a:hover {
    color: #888;
}

.initech-breadcrumb .breadcrumb-item.active {
    color: #888;
}

.initech-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    color: #333;
    content: "/";
    padding: 0 8px;
}

/* Hide old header styles */
#header.header,
.header:not(.initech-header),
.topbar:not(.initech-topbar),
.navbar:not(.initech-navbar),
.main-navbar-wrapper,
.master-breadcrumb:not(.initech-breadcrumb) {
    display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TYPOGRAPHY
   ═══════════════════════════════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--font-mono);
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--text-primary);
    margin-bottom: var(--spacing-md);
}

h1, .h1 { font-size: 28px; }
h2, .h2 { font-size: 22px; }
h3, .h3 { font-size: 18px; }
h4, .h4 { font-size: 16px; }
h5, .h5 { font-size: 14px; }
h6, .h6 { font-size: 12px; }

/* Section Headers - Letterpress Style */
.panel-heading,
.card-header,
.section-header,
.sidebar-header-title {
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.15em !important;
    color: var(--text-secondary) !important;
    background: transparent !important;
    border: none !important;
    padding: var(--spacing-sm) 0 !important;
}

a {
    color: var(--accent-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--accent-primary-bright);
    text-decoration: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HEADER & NAVIGATION
   ═══════════════════════════════════════════════════════════════════════════ */
#header,
.header {
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
}

.topbar {
    background: var(--bg-primary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    padding: var(--spacing-sm) 0 !important;
}

.topbar .btn {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--text-secondary) !important;
    background: transparent !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    padding: 4px 12px !important;
}

.topbar .btn:hover {
    color: var(--text-primary) !important;
    border-color: var(--border-secondary) !important;
    background: var(--bg-hover) !important;
}

.navbar {
    background: transparent !important;
    padding: var(--spacing-md) 0 !important;
}

.navbar-brand {
    font-family: var(--font-mono) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    letter-spacing: 0.05em !important;
}

.navbar-brand:hover {
    color: var(--accent-green) !important;
}

/* Main Navigation */
.main-navbar-wrapper {
    background: var(--bg-tertiary) !important;
    border-top: 1px solid var(--border-primary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
}

.navbar-nav .nav-link {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: var(--text-secondary) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
    border-radius: var(--radius-none) !important;
    transition: all var(--transition-fast) !important;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
    color: var(--accent-primary) !important;
    background: rgba(255, 51, 51, 0.05) !important;
}

.navbar-nav .dropdown-menu {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5) !important;
    padding: var(--spacing-xs) 0 !important;
}

.navbar-nav .dropdown-item {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    color: var(--text-secondary) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
}

.navbar-nav .dropdown-item:hover {
    color: var(--text-primary) !important;
    background: var(--bg-hover) !important;
}

/* Search Box */
.input-group.search {
    background: var(--bg-input) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
}

.input-group.search .form-control {
    background: transparent !important;
    border: none !important;
    color: var(--text-primary) !important;
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
}

.input-group.search .form-control::placeholder {
    color: var(--text-muted) !important;
}

.input-group.search .btn {
    background: transparent !important;
    border: none !important;
    color: var(--text-muted) !important;
}

/* Cart Button */
.cart-btn {
    color: var(--text-secondary) !important;
}

.cart-btn .badge {
    font-family: var(--font-mono) !important;
    background: var(--accent-primary) !important;
    color: var(--bg-primary) !important;
    border-radius: var(--radius-none) !important;
    font-size: 10px !important;
    padding: 2px 6px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BREADCRUMB
   ═══════════════════════════════════════════════════════════════════════════ */
.master-breadcrumb {
    background: var(--bg-primary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    padding: var(--spacing-sm) 0 !important;
}

.breadcrumb {
    background: transparent !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
}

.breadcrumb-item,
.breadcrumb-item a {
    color: var(--text-muted) !important;
}

.breadcrumb-item.active {
    color: var(--text-secondary) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--text-disabled) !important;
    content: "/" !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MAIN CONTENT AREA
   ═══════════════════════════════════════════════════════════════════════════ */
#main-body {
    background: var(--bg-primary) !important;
    padding: var(--spacing-xl) 0 !important;
    min-height: calc(100vh - 300px);
}

/* Landing Page - Full Width */
#main-body.initech-landing {
    padding: 0 !important;
}

.initech-landing-content {
    width: 100%;
}

.primary-bg-color {
    background: var(--bg-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CARDS & PANELS
   ═══════════════════════════════════════════════════════════════════════════ */
.card,
.panel {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    box-shadow: none !important;
    margin-bottom: var(--spacing-md) !important;
}

.card-header,
.panel-heading {
    background: var(--bg-tertiary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    padding: var(--spacing-md) !important;
}

.card-body,
.panel-body {
    padding: var(--spacing-lg) !important;
}

.card-footer,
.panel-footer {
    background: var(--bg-tertiary) !important;
    border-top: 1px solid var(--border-primary) !important;
    padding: var(--spacing-md) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════════════════════════════════════════════ */
.sidebar {
    margin-bottom: var(--spacing-lg);
}

.sidebar .card,
.sidebar .panel {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-primary) !important;
}

.sidebar .list-group {
    border-radius: var(--radius-none) !important;
}

.sidebar .list-group-item {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--border-primary) !important;
    color: var(--text-secondary) !important;
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
    transition: all var(--transition-fast) !important;
}

.sidebar .list-group-item:last-child {
    border-bottom: none !important;
}

.sidebar .list-group-item:hover,
.sidebar .list-group-item.active {
    background: var(--bg-hover) !important;
    color: var(--accent-primary) !important;
}

.sidebar .list-group-item.active {
    border-left: 2px solid var(--accent-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════════════════ */
.btn {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    border-radius: var(--radius-none) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
    transition: all var(--transition-fast) !important;
    box-shadow: none !important;
}

/* Primary Button - Outlined Red */
.btn-primary {
    background: transparent !important;
    border: 1px solid var(--accent-primary) !important;
    color: var(--accent-primary) !important;
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--accent-primary) !important;
    border-color: var(--accent-primary) !important;
    color: var(--bg-primary) !important;
}

/* Secondary Button */
.btn-secondary,
.btn-default {
    background: transparent !important;
    border: 1px solid var(--border-secondary) !important;
    color: var(--text-secondary) !important;
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-default:hover,
.btn-default:focus {
    background: var(--bg-hover) !important;
    border-color: var(--border-hover) !important;
    color: var(--text-primary) !important;
}

/* Success Button */
.btn-success {
    background: transparent !important;
    border: 1px solid var(--status-success) !important;
    color: var(--status-success) !important;
}

.btn-success:hover,
.btn-success:focus {
    background: var(--status-success) !important;
    color: var(--bg-primary) !important;
}

/* Danger Button */
.btn-danger {
    background: transparent !important;
    border: 1px solid var(--accent-red) !important;
    color: var(--accent-red) !important;
}

.btn-danger:hover,
.btn-danger:focus {
    background: var(--accent-red) !important;
    color: var(--text-primary) !important;
}

/* Warning Button */
.btn-warning {
    background: transparent !important;
    border: 1px solid var(--accent-amber) !important;
    color: var(--accent-amber) !important;
}

.btn-warning:hover,
.btn-warning:focus {
    background: var(--accent-amber) !important;
    color: var(--bg-primary) !important;
}

/* Info Button */
.btn-info {
    background: transparent !important;
    border: 1px solid var(--accent-primary-bright) !important;
    color: var(--accent-primary-bright) !important;
}

.btn-info:hover,
.btn-info:focus {
    background: var(--accent-primary-bright) !important;
    color: var(--bg-primary) !important;
}

/* Link Button */
.btn-link {
    color: var(--accent-primary) !important;
    text-decoration: none !important;
    border: none !important;
}

.btn-link:hover {
    color: var(--accent-primary-bright) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   FORMS
   ═══════════════════════════════════════════════════════════════════════════ */
.form-control {
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    background: var(--bg-input) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    color: var(--text-primary) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
    transition: border-color var(--transition-fast) !important;
}

.form-control:focus {
    background: var(--bg-input) !important;
    border-color: var(--accent-primary) !important;
    box-shadow: 0 0 0 1px var(--accent-primary) !important;
    color: var(--text-primary) !important;
}

.form-control::placeholder {
    color: var(--text-muted) !important;
}

.form-control:disabled,
.form-control[readonly] {
    background: var(--bg-tertiary) !important;
    color: var(--text-muted) !important;
}

/* Labels */
label,
.form-label,
.control-label {
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    color: var(--text-secondary) !important;
    margin-bottom: var(--spacing-xs) !important;
}

/* Select */
select.form-control {
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23666666' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    padding-right: 36px !important;
}

/* Checkbox & Radio */
.custom-control-input:checked ~ .custom-control-label::before {
    background-color: var(--accent-primary) !important;
    border-color: var(--accent-primary) !important;
}

.custom-control-label::before {
    background-color: var(--bg-input) !important;
    border: 1px solid var(--border-secondary) !important;
    border-radius: var(--radius-sm) !important;
}

/* Input Groups */
.input-group-text {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    background: var(--bg-tertiary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    color: var(--text-secondary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TABLES
   ═══════════════════════════════════════════════════════════════════════════ */
.table {
    color: var(--text-primary) !important;
    border-collapse: collapse !important;
}

.table thead th {
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--text-muted) !important;
    background: var(--bg-tertiary) !important;
    border: 1px solid var(--border-primary) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
}

.table td {
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    border: 1px solid var(--border-primary) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
    vertical-align: middle !important;
}

.table tbody tr {
    background: var(--bg-secondary) !important;
    transition: background var(--transition-fast) !important;
}

.table tbody tr:hover {
    background: var(--bg-hover) !important;
}

.table-striped tbody tr:nth-of-type(odd) {
    background: var(--bg-tertiary) !important;
}

.table-striped tbody tr:nth-of-type(odd):hover {
    background: var(--bg-hover) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BADGES & STATUS INDICATORS
   ═══════════════════════════════════════════════════════════════════════════ */
.badge {
    font-family: var(--font-mono) !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    border-radius: 100px !important;
    padding: 4px 10px !important;
}

.badge-primary,
.badge-info {
    background: rgba(255, 51, 51, 0.15) !important;
    color: var(--accent-primary) !important;
}

.badge-success {
    background: rgba(68, 204, 68, 0.15) !important;
    color: var(--status-success) !important;
}

.badge-warning {
    background: rgba(255, 170, 0, 0.15) !important;
    color: var(--accent-amber) !important;
}

.badge-danger {
    background: rgba(255, 68, 68, 0.15) !important;
    color: var(--accent-red) !important;
}

.badge-secondary {
    background: var(--bg-hover) !important;
    color: var(--text-secondary) !important;
}

/* Status Labels - Base Styling for all Bootstrap labels */
.label {
    font-family: var(--font-mono) !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    border-radius: 100px !important;
    padding: 4px 10px !important;
    display: inline-block !important;
    line-height: 1.4 !important;
}

.label-default,
.label-secondary {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #888 !important;
}

.label-active,
.label-success,
.status-active {
    background: rgba(34, 197, 94, 0.15) !important;
    color: #22c55e !important;
}

.label-pending,
.label-warning,
.status-pending {
    background: rgba(245, 158, 11, 0.15) !important;
    color: #f59e0b !important;
}

.label-cancelled,
.label-danger,
.status-cancelled,
.status-terminated {
    background: rgba(239, 68, 68, 0.15) !important;
    color: #ef4444 !important;
}

.label-info,
.label-primary {
    background: rgba(59, 130, 246, 0.15) !important;
    color: #3b82f6 !important;
}

/* Ticket Status Specific Labels */
.label-open,
.label[class*="open"] {
    background: rgba(59, 130, 246, 0.15) !important;
    color: #3b82f6 !important;
}

.label-answered,
.label[class*="answered"] {
    background: rgba(34, 197, 94, 0.15) !important;
    color: #22c55e !important;
}

.label-customer-reply,
.label[class*="customer"] {
    background: rgba(245, 158, 11, 0.15) !important;
    color: #f59e0b !important;
}

.label-in-progress,
.label[class*="progress"] {
    background: rgba(168, 85, 247, 0.15) !important;
    color: #a855f7 !important;
}

.label-closed,
.label[class*="closed"] {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #666 !important;
}

.label-on-hold,
.label[class*="hold"] {
    background: rgba(245, 158, 11, 0.15) !important;
    color: #f59e0b !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ALERTS
   ═══════════════════════════════════════════════════════════════════════════ */
.alert {
    font-family: var(--font-sans) !important;
    font-size: 14px !important;
    border-radius: var(--radius-none) !important;
    border-width: 1px !important;
    border-style: solid !important;
    padding: var(--spacing-md) !important;
}

.alert-success {
    background: rgba(68, 204, 68, 0.08) !important;
    border-color: var(--status-success) !important;
    color: var(--status-success) !important;
}

.alert-info {
    background: rgba(255, 51, 51, 0.08) !important;
    border-color: var(--accent-primary) !important;
    color: var(--accent-primary) !important;
}

.alert-warning {
    background: rgba(255, 170, 0, 0.08) !important;
    border-color: var(--accent-amber) !important;
    color: var(--accent-amber) !important;
}

.alert-danger {
    background: rgba(255, 68, 68, 0.08) !important;
    border-color: var(--accent-red-dim) !important;
    color: var(--accent-red) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════════════════════ */
.modal-content {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    box-shadow: 0 10px 50px rgba(0, 0, 0, 0.8) !important;
}

.modal-header {
    background: var(--bg-tertiary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    padding: var(--spacing-md) var(--spacing-lg) !important;
}

.modal-title {
    font-family: var(--font-mono) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--text-primary) !important;
}

.modal-body {
    padding: var(--spacing-lg) !important;
}

.modal-footer {
    background: var(--bg-tertiary) !important;
    border-top: 1px solid var(--border-primary) !important;
    padding: var(--spacing-md) var(--spacing-lg) !important;
}

.modal-backdrop.show {
    opacity: 0.85 !important;
}

.close {
    color: var(--text-muted) !important;
    opacity: 1 !important;
    text-shadow: none !important;
}

.close:hover {
    color: var(--text-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════════════════════════════════════════ */
.pagination {
    gap: 4px;
}

.page-link {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    color: var(--text-secondary) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
}

.page-link:hover {
    background: var(--bg-hover) !important;
    border-color: var(--border-secondary) !important;
    color: var(--text-primary) !important;
}

.page-item.active .page-link {
    background: var(--accent-primary) !important;
    border-color: var(--accent-primary) !important;
    color: var(--bg-primary) !important;
}

.page-item.disabled .page-link {
    background: var(--bg-tertiary) !important;
    color: var(--text-disabled) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PREMIUM FOOTER
   ═══════════════════════════════════════════════════════════════════════════ */
.initech-footer {
    background: #050505;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding: 80px 0 40px;
}

.initech-footer-inner {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 40px !important;
    padding-bottom: 60px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

/* Footer Brand */
.initech-footer-brand {
    flex: 0 0 auto !important;
    max-width: 220px !important;
    min-width: 200px;
}

.initech-footer-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: #e5e5e5;
    text-decoration: none;
    margin-bottom: 16px;
    transition: all 0.3s ease;
}

.initech-footer-logo:hover {
    color: #fafafa;
    text-decoration: none;
}

.initech-footer-logo svg.initech-logo-mark {
    flex-shrink: 0;
    color: #ff3333;
    filter: drop-shadow(0 0 8px rgba(255, 51, 51, 0.3));
    transition: all 0.3s ease;
}

.initech-footer-logo:hover svg.initech-logo-mark {
    filter: drop-shadow(0 0 16px rgba(255, 51, 51, 0.5));
}

.initech-footer-tagline {
    font-size: 14px;
    line-height: 1.6;
    color: #666;
    margin: 0;
}

/* Footer Links */
.initech-footer-links {
    display: flex !important;
    flex: 1 1 auto !important;
    justify-content: flex-end !important;
    gap: 48px !important;
}

.initech-footer-col h4 {
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    margin: 0 0 20px 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.initech-footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.initech-footer-col li {
    margin-bottom: 12px;
}

.initech-footer-col a {
    font-size: 14px;
    color: #666;
    text-decoration: none;
    transition: color 0.15s ease;
}

.initech-footer-col a:hover {
    color: #fff;
    text-decoration: none;
}

/* Footer Bottom */
.initech-footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 32px;
    flex-wrap: wrap;
    gap: 20px;
}

.initech-footer-copyright {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    color: #555;
}

.initech-copyright-symbol {
    color: var(--accent-primary);
}

.initech-footer-actions {
    display: flex;
    align-items: center;
    gap: 16px;
}

.initech-locale-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 6px;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    color: #888;
    cursor: pointer;
    transition: all 0.2s ease;
}

.initech-locale-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.initech-locale-btn svg {
    color: #555;
}

.initech-locale-divider {
    color: #333;
}

/* Admin Return Button */
.initech-admin-return {
    position: fixed;
    bottom: 20px;
    right: 20px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    background: var(--accent-primary);
    border-radius: 8px;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    text-decoration: none;
    box-shadow: 0 4px 20px rgba(255, 51, 51, 0.3);
    transition: all 0.2s ease;
    z-index: 1000;
}

.initech-admin-return:hover {
    background: var(--accent-primary-dim);
    transform: translateY(-2px);
    color: #fff;
    text-decoration: none;
}

/* Modal Styles */
.initech-modal .modal-content {
    background: #0a0a0a;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
}

.initech-modal .modal-header {
    background: transparent;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    padding: 24px 28px;
}

.initech-modal .modal-title {
    font-family: 'Inter', sans-serif;
    font-size: 18px;
    font-weight: 600;
    color: #fff;
}

.initech-modal-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: transparent;
    border: none;
    border-radius: 6px;
    color: #666;
    cursor: pointer;
    transition: all 0.15s ease;
}

.initech-modal-close:hover {
    background: rgba(255, 255, 255, 0.06);
    color: #fff;
}

.initech-modal .modal-body {
    padding: 28px;
}

.initech-modal-section {
    margin-bottom: 32px;
}

.initech-modal-section:last-child {
    margin-bottom: 0;
}

.initech-modal-section h6 {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #888;
    margin: 0 0 16px 0;
}

.initech-option-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.initech-option-item {
    display: block;
    padding: 12px 16px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    font-size: 14px;
    color: #888;
    text-decoration: none;
    text-align: center;
    transition: all 0.15s ease;
}

.initech-option-item:hover {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.1);
    color: #fff;
    text-decoration: none;
}

.initech-option-item.active {
    background: rgba(255, 51, 51, 0.1);
    border-color: rgba(255, 51, 51, 0.3);
    color: var(--accent-primary);
}

.initech-modal .modal-footer {
    background: transparent;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding: 20px 28px;
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

.initech-modal .initech-btn-ghost,
.initech-modal .initech-btn-primary {
    padding: 10px 20px;
    font-size: 14px;
    border-radius: 8px;
}

.initech-modal .initech-btn-ghost {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #888;
}

.initech-modal .initech-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.04);
    color: #fff;
}

.initech-modal .initech-btn-primary {
    background: var(--accent-primary);
    border: none;
    color: #fff;
}

.initech-modal .initech-btn-primary:hover {
    background: var(--accent-primary-dim);
}

/* Social links in footer */
.initech-footer-actions .list-inline {
    display: flex;
    gap: 8px;
    margin: 0;
    padding: 0;
}

.initech-footer-actions .list-inline-item {
    margin: 0;
}

.initech-footer-actions .list-inline-item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 6px;
    color: #666;
    transition: all 0.2s ease;
}

.initech-footer-actions .list-inline-item a:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.1);
    color: #fff;
}

/* Hide old footer */
#footer.footer:not(.initech-footer),
footer.footer:not(.initech-footer) {
    display: none !important;
}

/* Responsive Footer */
@media (max-width: 768px) {
    .initech-footer {
        padding: 60px 0 32px;
    }

    .initech-footer-inner {
        flex-wrap: wrap !important;
    }

    .initech-footer-brand {
        flex: 0 0 100% !important;
        max-width: none !important;
        text-align: center;
        margin-bottom: 16px;
    }

    .initech-footer-logo {
        justify-content: center;
    }

    .initech-footer-links {
        flex: 1 !important;
        flex-wrap: wrap;
        justify-content: space-around !important;
        text-align: center;
        gap: 32px 24px !important;
    }

    .initech-footer-col {
        flex: 0 0 calc(50% - 12px);
    }

    .initech-footer-bottom {
        flex-direction: column;
        text-align: center;
    }

    .initech-option-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .initech-footer-col {
        flex: 0 0 100%;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   CLIENT AREA SPECIFIC
   ═══════════════════════════════════════════════════════════════════════════ */

/* Dashboard Stats */
.stat-box,
.stats-item {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-primary) !important;
    padding: var(--spacing-lg) !important;
    text-align: center;
}

.stat-box .stat-number,
.stats-item .number {
    font-family: var(--font-mono) !important;
    font-size: 32px !important;
    font-weight: 600 !important;
    color: var(--accent-primary) !important;
}

.stat-box .stat-label,
.stats-item .label {
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--text-muted) !important;
}

/* Service/Product Status Indicators */
.service-status,
.product-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.service-status::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--text-muted);
}

.service-status.active::before {
    background: var(--status-success);
    box-shadow: 0 0 8px var(--status-success);
}

.service-status.pending::before {
    background: var(--accent-amber);
}

.service-status.suspended::before,
.service-status.terminated::before {
    background: var(--accent-red);
}

/* Invoice Status */
.invoice-status {
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

/* Domain Search Box */
.domain-search-container {
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border-primary) !important;
    padding: var(--spacing-2xl) !important;
}

.domain-search-container h2 {
    font-family: var(--font-mono) !important;
    color: var(--text-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TICKET SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */
.ticket-reply {
    background: var(--bg-tertiary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    margin-bottom: var(--spacing-md) !important;
    padding: var(--spacing-lg) !important;
}

.ticket-reply.staff-reply {
    border-left: 3px solid var(--accent-cyan) !important;
}

.ticket-reply.client-reply {
    border-left: 3px solid var(--accent-green) !important;
}

.ticket-reply-header {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    color: var(--text-muted) !important;
    margin-bottom: var(--spacing-sm) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   POPOVERS & TOOLTIPS
   ═══════════════════════════════════════════════════════════════════════════ */
.popover {
    background: var(--bg-elevated) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--radius-none) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5) !important;
}

.popover-header {
    background: var(--bg-tertiary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    font-family: var(--font-mono) !important;
    color: var(--text-primary) !important;
}

.popover-body {
    color: var(--text-secondary) !important;
}

.tooltip-inner {
    font-family: var(--font-mono) !important;
    font-size: 11px !important;
    background: var(--bg-elevated) !important;
    border-radius: var(--radius-none) !important;
    padding: 6px 12px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SCROLLBAR STYLING
   ═══════════════════════════════════════════════════════════════════════════ */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--bg-primary);
}

::-webkit-scrollbar-thumb {
    background: var(--border-secondary);
    border-radius: 0;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--border-hover);
}

/* ═══════════════════════════════════════════════════════════════════════════
   UTILITY CLASSES
   ═══════════════════════════════════════════════════════════════════════════ */
.text-terminal {
    font-family: var(--font-mono) !important;
}

.text-accent {
    color: var(--accent-green) !important;
}

.bg-terminal {
    background: var(--bg-primary) !important;
}

.border-terminal {
    border-color: var(--border-primary) !important;
}

/* Terminal-style cursor blink animation */
@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

.cursor-blink::after {
    content: '_';
    animation: blink 1s step-end infinite;
    color: var(--accent-primary);
}

/* Glow effect for active elements */
.glow-red {
    box-shadow: 0 0 20px rgba(255, 51, 51, 0.3);
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE ADJUSTMENTS
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 991px) {
    .navbar-collapse {
        background: var(--bg-elevated) !important;
        border: 1px solid var(--border-primary) !important;
        padding: var(--spacing-md) !important;
        margin-top: var(--spacing-sm) !important;
    }

    .navbar-nav .nav-link {
        padding: var(--spacing-sm) 0 !important;
        border-bottom: 1px solid var(--border-primary) !important;
    }
}

@media (max-width: 576px) {
    h1, .h1 { font-size: 22px; }
    h2, .h2 { font-size: 18px; }
    h3, .h3 { font-size: 16px; }

    .card-body,
    .panel-body {
        padding: var(--spacing-md) !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   AUTH PAGES - Hide all sidebars and extra elements
   ═══════════════════════════════════════════════════════════════════════════ */
.initech-auth-page .sidebar,
.initech-auth-page .col-lg-4,
.initech-auth-page .col-xl-3,
.initech-auth-page .sidebar-secondary,
.initech-auth-page .card-sidebar,
.initech-auth-page [menuItemName],
.initech-auth-content > .container > .row > .col-lg-4,
.initech-auth-content > .container > .row > .col-xl-3 {
    display: none !important;
}

.initech-auth-page .initech-auth-content {
    width: 100%;
    max-width: none;
}

.initech-auth-page .primary-content,
.initech-auth-page .col-lg-8,
.initech-auth-page .col-xl-9,
.initech-auth-page .col-12 {
    width: 100% !important;
    max-width: none !important;
    flex: 0 0 100% !important;
    padding: 0 !important;
}

.initech-auth-page .row {
    margin: 0 !important;
}

.initech-auth-page .container {
    max-width: none !important;
    padding: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BOOTSTRAP MARKDOWN EDITOR DARK THEME
   ═══════════════════════════════════════════════════════════════════════════ */

/* Main Editor Container */
.md-editor {
    display: block !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: rgba(0, 0, 0, 0.3) !important;
}

.md-editor.active {
    border-color: rgba(255, 51, 51, 0.5) !important;
    box-shadow: 0 0 0 3px rgba(255, 51, 51, 0.1) !important;
    outline: none !important;
}

/* Toolbar Header */
.md-editor > .md-header,
.md-editor .md-header {
    display: block !important;
    padding: 8px 10px !important;
    background: rgba(0, 0, 0, 0.5) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    margin: 0 !important;
}

/* Footer */
.md-editor .md-footer {
    display: block !important;
    padding: 8px 12px !important;
    background: rgba(0, 0, 0, 0.4) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
    color: rgba(255, 255, 255, 0.4) !important;
    font-size: 0.75rem !important;
}

/* Preview Area */
.md-editor > .md-preview {
    background: rgba(0, 0, 0, 0.2) !important;
    border-top: 1px dashed rgba(255, 255, 255, 0.1) !important;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.1) !important;
    min-height: 10px !important;
    overflow: auto !important;
    color: rgba(255, 255, 255, 0.8) !important;
    padding: 1rem !important;
}

/* Textarea - Multiple selectors for specificity */
.md-editor > textarea,
.md-editor textarea,
.md-editor > textarea.form-control,
.md-editor textarea.form-control,
.md-editor textarea.md-input,
textarea.md-input,
div.md-editor > textarea,
div.md-editor textarea {
    font-family: 'JetBrains Mono', Menlo, Monaco, Consolas, monospace !important;
    font-size: 0.85rem !important;
    line-height: 1.7 !important;
    outline: 0 !important;
    margin: 0 !important;
    display: block !important;
    padding: 1rem !important;
    width: 100% !important;
    border: 0 !important;
    border-top: 1px dashed rgba(255, 255, 255, 0.08) !important;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.08) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: rgba(0, 0, 0, 0.3) !important;
    color: #ffffff !important;
    min-height: 200px !important;
    resize: vertical !important;
}

.md-editor > textarea:focus,
.md-editor textarea:focus,
div.md-editor > textarea:focus,
div.md-editor textarea:focus {
    box-shadow: none !important;
    background: rgba(0, 0, 0, 0.4) !important;
    outline: none !important;
    border-color: transparent !important;
}

.md-editor > textarea::placeholder,
.md-editor textarea::placeholder {
    color: rgba(255, 255, 255, 0.3) !important;
}

/* Override Bootstrap form-control defaults inside md-editor */
.md-editor .form-control,
.md-editor input.form-control,
.md-editor textarea.form-control {
    background: rgba(0, 0, 0, 0.3) !important;
    color: #ffffff !important;
    border: none !important;
}

/* Toolbar Buttons */
.md-editor .md-header .btn-toolbar {
    margin: 0 !important;
}

.md-editor .md-header .btn-group {
    margin-right: 5px !important;
}

.md-editor .md-header .btn,
.md-editor .md-header button {
    background: transparent !important;
    border: 1px solid transparent !important;
    color: rgba(255, 255, 255, 0.5) !important;
    border-radius: 4px !important;
    padding: 5px 10px !important;
    font-size: 14px !important;
    transition: all 0.2s ease !important;
}

.md-editor .md-header .btn:hover,
.md-editor .md-header button:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}

.md-editor .md-header .btn:focus,
.md-editor .md-header button:focus {
    box-shadow: none !important;
    outline: none !important;
}

.md-editor .md-header .btn.active,
.md-editor .md-header button.active {
    background: rgba(255, 51, 51, 0.15) !important;
    color: #ff3333 !important;
    border-color: rgba(255, 51, 51, 0.3) !important;
}

/* Glyphicon/Icon styling */
.md-editor .md-header .glyphicon,
.md-editor .md-header .fa,
.md-editor .md-header [class^="fa-"],
.md-editor .md-header i {
    color: inherit !important;
}

/* Dropdown menus in toolbar */
.md-editor .md-header .dropdown-menu {
    background: #1a1a1a !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
}

.md-editor .md-header .dropdown-menu > li > a {
    color: rgba(255, 255, 255, 0.7) !important;
    padding: 8px 16px !important;
}

.md-editor .md-header .dropdown-menu > li > a:hover {
    background: rgba(255, 51, 51, 0.1) !important;
    color: #ffffff !important;
}

/* Controls (resize handle etc) */
.md-editor .md-controls {
    float: right !important;
    padding: 3px !important;
}

.md-editor .md-controls .md-control {
    right: 5px !important;
    color: rgba(255, 255, 255, 0.3) !important;
    padding: 3px 3px 3px 10px !important;
}

.md-editor .md-controls .md-control:hover {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* Fullscreen Mode */
.md-editor.md-fullscreen-mode {
    width: 100% !important;
    height: 100% !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 99999 !important;
    padding: 60px 30px 15px !important;
    background: #0a0a0a !important;
    border: 0 !important;
    border-radius: 0 !important;
}

.md-editor.md-fullscreen-mode .md-footer {
    display: none !important;
}

.md-editor.md-fullscreen-mode .md-input,
.md-editor.md-fullscreen-mode .md-preview,
.md-editor.md-fullscreen-mode textarea {
    margin: 0 auto !important;
    height: 100% !important;
    font-size: 18px !important;
    padding: 20px !important;
    color: rgba(255, 255, 255, 0.7) !important;
    line-height: 1.6em !important;
    resize: none !important;
    box-shadow: none !important;
    background: #0a0a0a !important;
    border: 0 !important;
}

.md-editor.md-fullscreen-mode .md-preview {
    color: rgba(255, 255, 255, 0.8) !important;
    overflow: auto !important;
}

.md-editor.md-fullscreen-mode .md-input:focus,
.md-editor.md-fullscreen-mode .md-input:hover,
.md-editor.md-fullscreen-mode textarea:focus,
.md-editor.md-fullscreen-mode textarea:hover {
    color: #ffffff !important;
    background: #0a0a0a !important;
}

.md-editor.md-fullscreen-mode .md-header {
    background: transparent !important;
    text-align: center !important;
    position: fixed !important;
    width: 100% !important;
    top: 20px !important;
    border: none !important;
}

.md-editor.md-fullscreen-mode .btn-group {
    float: none !important;
}

.md-editor.md-fullscreen-mode .btn {
    border: 0 !important;
    background: transparent !important;
    color: rgba(255, 255, 255, 0.4) !important;
}

.md-editor.md-fullscreen-mode .btn.active,
.md-editor.md-fullscreen-mode .btn:active,
.md-editor.md-fullscreen-mode .btn:focus,
.md-editor.md-fullscreen-mode .btn:hover {
    box-shadow: none !important;
    color: #ffffff !important;
}

.md-editor.md-fullscreen-mode .md-fullscreen-controls {
    position: absolute !important;
    top: 20px !important;
    right: 20px !important;
    text-align: right !important;
    z-index: 1002 !important;
    display: block !important;
}

.md-editor.md-fullscreen-mode .md-fullscreen-controls a {
    color: rgba(255, 255, 255, 0.4) !important;
    clear: right !important;
    margin: 10px !important;
    width: 30px !important;
    height: 30px !important;
    text-align: center !important;
}

.md-editor.md-fullscreen-mode .md-fullscreen-controls a:hover {
    color: #ffffff !important;
    text-decoration: none !important;
}

.md-editor .md-fullscreen-controls {
    display: none !important;
}

.md-nooverflow {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
}

/* Status bar at bottom */
.md-editor .markdown-editor-status,
.markdown-editor-status {
    background: rgba(0, 0, 0, 0.3) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
    padding: 6px 12px !important;
    color: rgba(255, 255, 255, 0.4) !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 0.7rem !important;
}

/* Preview content styling */
.md-editor .md-preview h1,
.md-editor .md-preview h2,
.md-editor .md-preview h3,
.md-editor .md-preview h4 {
    color: #ffffff !important;
    margin-top: 1rem !important;
}

.md-editor .md-preview code {
    background: rgba(255, 51, 51, 0.1) !important;
    color: #ff6666 !important;
    padding: 2px 6px !important;
    border-radius: 4px !important;
    font-family: 'JetBrains Mono', monospace !important;
}

.md-editor .md-preview pre {
    background: rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px !important;
    padding: 1rem !important;
    color: rgba(255, 255, 255, 0.8) !important;
}

.md-editor .md-preview a {
    color: #ff3333 !important;
}

.md-editor .md-preview blockquote {
    border-left: 3px solid #ff3333 !important;
    padding-left: 1rem !important;
    color: rgba(255, 255, 255, 0.6) !important;
    margin: 1rem 0 !important;
}

/* Container with markdown-editor class */
.container-markdown-editor {
    border-radius: 8px !important;
    overflow: hidden !important;
}
