/* Pune.mk Custom CSS - Extra helles und freundliches Design ohne dunkle Elemente */

:root {
  --pune-primary: #ff6b35;      /* Orange Primary */
  --pune-primary-light: #ff8856;
  --pune-primary-dark: #e55a2e;
  --pune-secondary: #ffffff;    /* Weißer Hintergrund */
  --pune-accent: #ff7043;       /* Helleres Orange */
  --pune-accent-light: #ff9e7f;
  --pune-text: #000000;         /* Black text for better readability */
  --pune-text-light: #333333;   /* Dark gray for secondary text */
  --pune-light-bg: #ffffff;     /* Weißer Hintergrund */
  --pune-card-shadow: 0 3px 10px rgba(0, 0, 0, 0.05);
}

/* Global Styles */
body {
  background-color: var(--pune-light-bg);
  color: var(--pune-text);
  font-family: 'Nunito', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Enforce black text for all text elements */
h1, h2, h3, h4, h5, h6,
p, span, div, 
.text-muted, .text-secondary,
.card-text, .card-title,
.form-label, .form-control,
.btn, .badge,
.list-group-item,
.table td, .table th,
.alert,
.modal-body, .modal-header,
.breadcrumb-item,
.dropdown-item,
small, .small {
  color: #000000 !important;
}

/* Specific overrides for light text elements */
.text-light, .text-white {
  color: #000000 !important;
}

/* Form elements with black text */
.form-control, .form-select, .form-control:focus {
  color: #000000 !important;
}

/* Button text styling */
.btn {
  color: #000000 !important;
}

/* Link styling with black text */
a {
  color: var(--pune-primary) !important;
}

a:hover {
  color: var(--pune-primary-dark) !important;
}

/* Navbar styling */
.navbar-dark, .navbar, .navbar-light {
  background-color: #ffffff !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.navbar-dark .navbar-nav .nav-link,
.navbar-dark .navbar-brand,
.navbar-light .navbar-nav .nav-link,
.navbar-light .navbar-brand,
.navbar .navbar-nav .nav-link,
.navbar .navbar-brand {
  color: var(--pune-primary) !important;
}

.navbar-dark .navbar-toggler,
.navbar-light .navbar-toggler,
.navbar .navbar-toggler {
  border-color: rgba(0, 0, 0, 0.1) !important;
  color: var(--pune-primary) !important;
}

.navbar-brand {
  font-weight: 700;
  letter-spacing: 0.5px;
}

/* Cards styling - Modern und hell */
.card {
  border: none;
  border-radius: 12px;
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
  background-color: #ffffff;
  overflow: hidden;
  margin-bottom: 20px;
}

.card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
}

.card-header {
  background-color: #ffffff;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  padding: 1.2rem 1.5rem;
  font-weight: 600;
}

.card-body {
  padding: 1.5rem;
}

/* Card Animationen */
.card-hover-reveal .card-hover-content {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s ease;
}

.card:hover .card-hover-reveal .card-hover-content {
  opacity: 1;
  transform: translateY(0);
}

.card-header {
  border-top-left-radius: 0.75rem !important;
  border-top-right-radius: 0.75rem !important;
  background-color: #fff;
  border-bottom: 1px solid rgba(0,0,0,.05);
}

/* Helle Card-Header für alle farbigen Headers */
.card-header.bg-primary {
  background-color: #fff5f0 !important;
  color: #ff6b35 !important;
  border-bottom: 1px solid rgba(255, 107, 53, 0.2);
}

.card-header.bg-success {
  background-color: #f0fff7 !important;
  color: #2ecc71 !important;
  border-bottom: 1px solid rgba(46, 204, 113, 0.2);
}

.card-header.bg-info {
  background-color: #f0faff !important;
  color: #17a2b8 !important;
  border-bottom: 1px solid rgba(23, 162, 184, 0.2);
}

.card-header.bg-warning {
  background-color: #fffdf0 !important;
  color: #ffb74d !important;
  border-bottom: 1px solid rgba(255, 183, 77, 0.2);
}

.card-header.bg-danger {
  background-color: #fff0f0 !important;
  color: #dc3545 !important;
  border-bottom: 1px solid rgba(220, 53, 69, 0.2);
}

/* Button styles - Modern mit Animationen */
.btn {
  border-radius: 8px;
  padding: 0.6rem 1.25rem;
  font-weight: 500;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.btn::after {
  content: '';
  position: absolute;
  width: 0%;
  height: 100%;
  top: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.1);
  transition: width 0.3s ease;
  z-index: 1;
}

.btn:hover::after {
  width: 100%;
}

.btn-primary {
  background-color: #ff6b35 !important;
  border-color: #ff6b35 !important;
  box-shadow: 0 4px 10px rgba(255, 107, 53, 0.2);
}

.btn-primary:hover, .btn-primary:focus {
  background-color: #e55a2e !important;
  border-color: #e55a2e !important;
  box-shadow: 0 6px 15px rgba(255, 107, 53, 0.3);
  transform: translateY(-2px);
}

.btn-outline-primary {
  color: #ff6b35 !important;
  border-color: #ff6b35 !important;
  background-color: transparent;
}

.btn-outline-primary:hover {
  background-color: #ff6b35 !important;
  border-color: #ff6b35 !important;
  color: white !important;
  box-shadow: 0 6px 15px rgba(255, 107, 53, 0.3);
  transform: translateY(-2px);
}

/* Global text-primary override */
.text-primary {
  color: #ff6b35 !important;
}

/* Accent buttons for actions */
.btn-accent {
  background-color: var(--pune-accent);
  border-color: var(--pune-accent);
  color: white;
}

.btn-accent:hover, .btn-accent:focus {
  background-color: var(--pune-accent-light);
  border-color: var(--pune-accent-light);
  color: white;
}

.btn-outline-accent {
  color: var(--pune-accent);
  border-color: var(--pune-accent);
}

.btn-outline-accent:hover {
  background-color: var(--pune-accent);
  border-color: var(--pune-accent);
  color: white;
}

/* Dashboard cards */
.dashboard-stats-card {
  text-align: center;
  padding: 1.5rem;
}

.dashboard-stats-card h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: var(--pune-primary);
}

.dashboard-stats-card p {
  font-size: 0.9rem;
  color: var(--pune-text-light);
  margin-bottom: 0;
}

.dashboard-stats-card .icon {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  color: var(--pune-accent);
}

/* Accent styling for job cards and highlights */
.badge-accent {
  background-color: var(--pune-accent);
  color: white;
}

/* Highlight items with accent color */
.accent-highlight {
  color: var(--pune-accent);
}

/* Job Offers */
.job-card {
  margin-bottom: 1.5rem;
}

.job-card .job-title {
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--pune-primary-dark);
}

.job-card .job-company {
  color: var(--pune-text-light);
  font-weight: 600;
}

.job-card .job-location, .job-card .job-type {
  font-size: 0.85rem;
}

.badge {
  padding: 0.5em 0.8em;
  font-weight: 600;
  border-radius: 6px;
}

/* Helle Badges für die verschiedenen Rollen */
.badge.bg-primary {
  background-color: #fff5f0 !important;
  color: #ff6b35 !important;
  border: 1px solid rgba(255, 107, 53, 0.3);
}

.badge.bg-success {
  background-color: #f0fff7 !important;
  color: #2ecc71 !important;
  border: 1px solid rgba(46, 204, 113, 0.3);
}

.badge.bg-warning {
  background-color: #fffdf0 !important;
  color: #ffb74d !important;
  border: 1px solid rgba(255, 183, 77, 0.3);
}

.badge.bg-info {
  background-color: #f0faff !important;
  color: #17a2b8 !important;
  border: 1px solid rgba(23, 162, 184, 0.3);
}

.badge.bg-danger {
  background-color: #fff0f0 !important;
  color: #dc3545 !important;
  border: 1px solid rgba(220, 53, 69, 0.3);
}

.badge.bg-secondary {
  background-color: #f7f7f7 !important;
  color: #6c757d !important;
  border: 1px solid rgba(108, 117, 125, 0.3);
}

/* Tables */
.table th {
  font-weight: 600;
  color: var(--pune-text);
  border-top: none;
  background-color: rgba(0, 0, 0, 0.01);
}

.table-hover tbody tr:hover {
  background-color: rgba(75, 60, 205, 0.04);
}

/* Pagination */
.page-item.active .page-link {
  background-color: var(--pune-primary);
  border-color: var(--pune-primary);
}

.page-link {
  color: var(--pune-primary);
}

/* Forms - Modern mit Animationen */
.form-control {
  border-radius: 8px;
  padding: 0.8rem 1rem;
  border: 1px solid rgba(0, 0, 0, 0.1);
  background-color: #ffffff;
  transition: all 0.3s ease;
  font-size: 1rem;
}

.form-control:focus {
  border-color: var(--pune-primary);
  box-shadow: 0 0 0 4px rgba(0, 102, 204, 0.1);
  transform: translateY(-2px);
}

.form-control::placeholder {
  color: #999;
  font-weight: 400;
}

.form-label {
  font-weight: 600;
  color: var(--pune-text);
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
}

.input-group {
  transition: all 0.3s ease;
}

.input-group:focus-within {
  transform: translateY(-2px);
}

/* Form Validierung */
.form-control.is-valid {
  border-color: var(--success);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%2328b78d' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

.form-control.is-invalid {
  border-color: var(--danger);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

/* Print styles */
@media print {
  body {
    background-color: white !important;
    color: black !important;
  }
  
  .card {
    box-shadow: none !important;
    border: 1px solid #eee !important;
  }
  
  .no-print {
    display: none !important;
  }
  
  .container {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }
}

/* Language selector */
.dropdown-item.active {
  background-color: var(--pune-primary);
  color: white;
}

/* Verbesserte Lesbarkeit für Dropdown-Menüs und alle Elemente */
.dropdown-menu, .card, .bg-white, .modal-content, .list-group, .toast {
  background-color: white !important;
}

.dropdown-item, .card-title, .card-text, p, span, .list-group-item, .modal-title, .toast-body, 
.btn-light, .badge-light, .text-muted, th, td, h1, h2, h3, h4, h5, h6, label, 
input, textarea, select, .table, .form-control, a:not(.btn):not(.nav-link) {
  color: #333 !important;
}

.dropdown-item:hover {
  background-color: #f0f0f0 !important;
}

/* Helle Karten anstelle von farbigen Karten */
.card.text-white.bg-primary {
  background-color: #f0f7ff !important;
  color: #333 !important;
  border: 1px solid rgba(26, 115, 232, 0.2);
}

.card.text-white.bg-success {
  background-color: #f0fff7 !important;
  color: #333 !important;
  border: 1px solid rgba(46, 204, 113, 0.2);
}

.card.text-white.bg-warning {
  background-color: #fffdf0 !important;
  color: #333 !important;
  border: 1px solid rgba(255, 183, 77, 0.2);
}

.card.text-white.bg-info {
  background-color: #f0faff !important;
  color: #333 !important;
  border: 1px solid rgba(23, 162, 184, 0.2);
}

.card.text-white.bg-danger {
  background-color: #fff0f0 !important;
  color: #333 !important;
  border: 1px solid rgba(220, 53, 69, 0.2);
}

/* Großzahlen in Statistics Cards */
.card.text-white.bg-primary h1, 
.card.text-white.bg-success h1,
.card.text-white.bg-warning h1,
.card.text-white.bg-info h1,
.card.text-white.bg-danger h1 {
  color: #444 !important;
  font-weight: bold;
}

/* Application documents */
.bg-light {
  background-color: var(--pune-secondary) !important;
}

/* CRITICAL: Header Menu muss IMMER im Vordergrund sein - z-index Fix */
.navbar,
nav.navbar {
  z-index: 99999 !important;
  position: relative;
}

.navbar-collapse,
#navbarNav {
  z-index: 99999 !important;
}

/* ULTIMATE FIX: Dropdown-Menus mit MAXIMALEN z-index und position fixed fallback */
.navbar .dropdown-menu,
.user-dropdown .dropdown-menu,
.dropdown-menu {
  z-index: 2147483647 !important; /* Maximum possible z-index value */
  position: fixed !important; /* Escape ALL stacking contexts */
}

/* Sicherstellen, dass navbar-collapse beim Aufklappen über allem liegt */
.navbar-collapse.show,
.navbar-collapse.collapsing {
  z-index: 99999 !important;
}

/* KRITISCH: Navbar-Container darf KEINEN eigenen Stacking-Context haben! */
/* Navbar-Container muss position: static bleiben, damit Dropdown entkommen kann */
.navbar .container,
.navbar .container-fluid {
  position: static !important;
  z-index: auto !important;
}