﻿/* Please see documentation at https://docs.microsoft.com/aspnet/core/client-side/bundling-and-minification
for details on configuring this project to bundle and minify static web assets. */

a.navbar-brand {
  white-space: normal;
  text-align: center;
  word-break: break-all;
}

/* Provide sufficient contrast against white background */
a {
  color: #0366d6;
}

/* Override link color for buttons */
a.btn-primary {
  color: #fff !important;
}

a.btn-secondary {
  color: #6c757d !important;
}

.btn-primary {
  color: #fff;
  background-color: #1b6ec2;
  border-color: #1861ac;
}

.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
  color: #fff;
  background-color: #1b6ec2;
  border-color: #1861ac;
}

/* Sticky footer styles
-------------------------------------------------- */
html {
  font-size: 14px;
}
@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.border-top {
  border-top: 1px solid #e5e5e5;
}
.border-bottom {
  border-bottom: 1px solid #e5e5e5;
}

.box-shadow {
  box-shadow: 0 .25rem .75rem rgba(0, 0, 0, .05);
}

button.accept-policy {
  font-size: 1rem;
  line-height: inherit;
}

/* Sticky footer styles
-------------------------------------------------- */
html {
  position: relative;
  min-height: 100%;
}

body {
  /* Margin bottom by footer height */
  margin-bottom: 60px;
}
.footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  white-space: nowrap;
  line-height: 60px; /* Vertically center the text there */
}

/* Logo and animation
-------------------------------------------------- */
.logo-wrapper {
  position: relative;
  display: inline-block;
}

.navbar-logo {
  height: 40px;
  width: auto;
  object-fit: contain;
  position: relative;
  z-index: 2;
}

.logo-circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 50px;
  height: 50px;
  background-color: rgba(255, 255, 255, 0.25);
  border-radius: 50%;
  filter: blur(10px);
  z-index: 1;
}

.welcome-logo-wrapper {
  position: relative;
  display: inline-block;
}

.welcome-logo {
  height: 250px;
  width: auto;
  object-fit: contain;
  position: relative;
  z-index: 2;
}

.welcome-logo-circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 300px;
  height: 300px;
  background-color: rgba(255, 255, 255, 0.15);
  border-radius: 50%;
  filter: blur(25px);
  z-index: 1;
}

#banner-logo:hover {
  cursor: url('../images/music-note.cur'),
      url('../images/music-note.png') 16 16,
      pointer;
}

#splash {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  justify-content: center;
  z-index: 9999;

  /* blurred background */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background-color: rgba(255, 255, 255, 0.2);

  overflow: hidden;

  opacity: 1;
  transition: opacity 0.5s ease; /* ensure smooth fade */
}

.splash-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
}

#splash-logo {
  position: absolute;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: 100%;
  object-fit: contain;
}

/* --------------------------------------------------
Admin Area Theme Integration
--------------------------------------------------
Admin area styles integrated into main theme system
*/

/* Admin-specific icon colors for better consistency */
.text-primary .fas,
.text-primary .fa {
    color: var(--color-coral) !important;
}

.text-info .fas,
.text-info .fa {
    color: var(--color-accent) !important;
}

.text-success .fas,
.text-success .fa {
    color: var(--color-teal) !important;
}

.text-warning .fas,
.text-warning .fa {
    color: var(--color-coral) !important;
}

.text-danger .fas,
.text-danger .fa {
    color: var(--color-danger) !important;
}

/* Card header icons in admin area */
.card-header .fas,
.card-header .fa {
    color: var(--color-white) !important;
}

/* Admin area specific card styling */
.admin-card .card-header {
    background-color: var(--color-primary) !important;
    color: var(--color-white) !important;
}

[data-bs-theme="dark"] .admin-card .card-header {
    background-color: var(--color-secondary) !important;
}

/* Admin card backgrounds with better contrast */
.admin-card.bg-coral {
    background-color: var(--color-coral) !important;
    color: var(--color-white) !important;
}

.admin-card.bg-coral .card-title,
.admin-card.bg-coral .card-text {
    color: var(--color-white) !important;
}

.admin-card.bg-coral .btn-light {
    background-color: rgba(255, 255, 255, 0.9) !important;
    color: var(--color-coral) !important;
    border-color: rgba(255, 255, 255, 0.9) !important;
}

.admin-card.bg-coral .btn-light:hover {
    background-color: var(--color-white) !important;
    color: var(--color-coral) !important;
    border-color: var(--color-white) !important;
}

/* Dark mode admin card improvements */
[data-bs-theme="dark"] .admin-card.bg-coral {
    background-color: var(--color-coral) !important;
}

[data-bs-theme="dark"] .admin-card.bg-coral .btn-light {
    background-color: rgba(255, 255, 255, 0.95) !important;
    color: var(--color-coral) !important;
}

[data-bs-theme="dark"] .admin-card.bg-coral .btn-light:hover {
    background-color: var(--color-white) !important;
    color: var(--color-coral) !important;
}

/* Migration-specific styling improvements */
.migration-step-card {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

.migration-step-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

[data-bs-theme="dark"] .migration-step-card:hover {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.3);
}

/* Admin area form styling */
.admin-form .form-control:focus,
.admin-form .form-select:focus {
    border-color: var(--color-accent) !important;
    box-shadow: 0 0 0 0.25rem rgba(64, 207, 255, 0.25) !important;
}

/* Admin area table styling */
.admin-table .table thead {
    background-color: var(--color-primary) !important;
    color: var(--color-white) !important;
}

[data-bs-theme="dark"] .admin-table .table thead {
    background-color: var(--color-secondary) !important;
}

/* Admin area modal styling */
.admin-modal .modal-header {
    background-color: var(--color-primary) !important;
    color: var(--color-white) !important;
}

[data-bs-theme="dark"] .admin-modal .modal-header {
    background-color: var(--color-teal) !important;
}

/* Admin area progress styling */
.admin-progress .progress-bar {
    background-color: var(--color-coral) !important;
}

.admin-progress .progress-bar.bg-info {
    background-color: var(--color-accent) !important;
}

.admin-progress .progress-bar.bg-success {
    background-color: var(--color-teal) !important;
}

.admin-progress .progress-bar.bg-warning {
    background-color: var(--color-coral) !important;
}

.admin-progress .progress-bar.bg-danger {
    background-color: var(--color-danger) !important;
}

/* Admin area list group styling */
.admin-list-group .list-group-item {
    border-color: var(--bs-border-color) !important;
}

.admin-list-group .list-group-item:hover {
    background-color: var(--color-light) !important;
}

[data-bs-theme="dark"] .admin-list-group .list-group-item:hover {
    background-color: var(--color-secondary) !important;
}

/* Admin area alert styling improvements */
.admin-alert .alert {
    border-left: 4px solid transparent;
}

.admin-alert .alert-info {
    border-left-color: var(--color-accent) !important;
}

.admin-alert .alert-success {
    border-left-color: var(--color-teal) !important;
}

.admin-alert .alert-warning {
    border-left-color: var(--color-coral) !important;
}

.admin-alert .alert-danger {
    border-left-color: var(--color-danger) !important;
}

/* Better contrast for ALL secondary buttons in dark mode */
[data-bs-theme="dark"] .btn-secondary {
    background-color: #6c757d !important;
    border-color: #6c757d !important;
    color: var(--color-white) !important;
}

[data-bs-theme="dark"] .btn-secondary:hover {
    background-color: #5a6268 !important;
    border-color: #5a6268 !important;
    color: var(--color-white) !important;
}

[data-bs-theme="dark"] .btn-outline-secondary {
    color: #adb5bd !important;
    border-color: #adb5bd !important;
}

[data-bs-theme="dark"] .btn-outline-secondary:hover {
    background-color: #6c757d !important;
    border-color: #6c757d !important;
    color: var(--color-white) !important;
}

/* Better contrast for info buttons */
[data-bs-theme="dark"] .admin-btn.btn-info {
    background-color: var(--color-accent) !important;
    border-color: var(--color-accent) !important;
    color: var(--color-primary) !important;
}

[data-bs-theme="dark"] .admin-btn.btn-info:hover {
    background-color: #2BB8E6 !important;
    border-color: #2BB8E6 !important;
    color: var(--color-primary) !important;
}

/* Coral button styling */
.btn-coral {
    background-color: var(--color-coral) !important;
    border-color: var(--color-coral) !important;
    color: var(--color-white) !important;
}

.btn-coral:hover {
    background-color: #e65252 !important;
    border-color: #e65252 !important;
    color: var(--color-white) !important;
}

/* Theme button classes */
.btn-info-theme {
    background-color: var(--color-accent) !important;
    border-color: var(--color-accent) !important;
    color: var(--color-white) !important;
}

.btn-info-theme:hover {
    background-color: #2BB8E6 !important;
    border-color: #2BB8E6 !important;
    color: var(--color-white) !important;
}

.btn-success-theme {
    background-color: var(--color-teal) !important;
    border-color: var(--color-teal) !important;
    color: var(--color-white) !important;
}

.btn-success-theme:hover {
    background-color: #248A9F !important;
    border-color: #248A9F !important;
    color: var(--color-white) !important;
}

.btn-warning-theme {
    background-color: var(--color-coral) !important;
    border-color: var(--color-coral) !important;
    color: var(--color-white) !important;
}

.btn-warning-theme:hover {
    background-color: #e65252 !important;
    border-color: #e65252 !important;
    color: var(--color-white) !important;
}

/* Admin area button styling */
.admin-btn {
    transition: all 0.2s ease-in-out;
}

.admin-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.15);
}

/* Admin area specific button hover effects */
.admin-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

[data-bs-theme="dark"] .admin-btn:hover {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.3);
}

/* Admin area status indicators */
.status-active {
    color: var(--color-teal) !important;
}

.status-inactive {
    color: var(--color-coral) !important;
}

.status-pending {
    color: var(--color-accent) !important;
}

/* Migration log styling */
.migration-log {
    background-color: var(--color-primary) !important;
    color: var(--color-white) !important;
    border: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] .migration-log {
    background-color: var(--color-secondary) !important;
}

/* =============================================
   Invitation Pages Styling
   ============================================= */

/* Workspace icon styling for invitation tables */
.invitation-workspace-icon {
    font-size: 1.2rem;
    width: 24px;
    text-align: center;
    display: inline-block;
}

/* Invitation table styling */
.invitation-table th {
    background-color: var(--bs-primary);
    color: white;
    border: none;
    font-weight: 500;
}

.invitation-table-striped > tbody > tr:nth-of-type(odd) > td {
    background-color: rgba(0, 0, 0, 0.02);
}

[data-bs-theme="dark"] .invitation-table-striped > tbody > tr:nth-of-type(odd) > td {
    background-color: rgba(255, 255, 255, 0.05);
}

/* Action button alignment for invitation tables */
.invitation-actions-cell {
    width: 200px;
    text-align: center;
}

.invitation-actions-single {
    width: 150px;
    text-align: center;
}

.invitation-actions-group {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    align-items: center;
}

/* Invitation status badges */
.invitation-status-pending {
    background-color: var(--bs-primary);
    color: white;
}

.invitation-status-accepted {
    background-color: var(--bs-success);
    color: white;
}

.invitation-status-declined {
    background-color: var(--bs-danger);
    color: white;
}

.invitation-status-revoked {
    background-color: var(--bs-secondary);
    color: white;
}

.invitation-status-expired {
    background-color: var(--bs-warning);
    color: var(--bs-dark);
}


/* Ensure invitation action buttons are properly styled */
.invitation-actions-single .btn,
.invitation-actions-cell .btn {
    min-width: 80px;
}

.invitation-actions-group .btn {
    min-width: 70px;
}

/* Debug: Make sure workspace icons are visible */
.invitation-workspace-icon {
    min-width: 24px;
    height: 24px;
    line-height: 24px;
    text-align: center;
    display: inline-block;
    font-size: 16px;
}

/* Tooltip styling for workspace descriptions */
.invitation-workspace-icon + div i[data-bs-toggle="tooltip"] {
    font-size: 12px;
    cursor: help;
}

/* Ensure consistent row heights for better button alignment */
.invitation-table tbody tr {
    height: 60px; /* Fixed height for consistent alignment */
}

.invitation-table tbody td {
    vertical-align: middle !important;
}

/* Better button alignment in action columns */
.invitation-actions-cell,
.invitation-actions-single {
    vertical-align: middle !important;
}

.invitation-actions-group {
    align-items: center;
    justify-content: center;
    height: 100%;
}