/* ===============================
   THEME CORE (Light + Dark)
   Paleta profissional, alto contraste, sem gradientes exagerados
   =============================== */
:root {
  /* Light palette */
  --color-bg: #f5f7fa;
  --color-bg-alt: #eef1f5;
  --color-surface: #ffffff;
  --color-surface-alt: #f9fafb;
  --color-border: #e3e8ef;
  --color-border-strong: #cdd5df;
  --color-text: #1e2430;
  --color-text-soft: #4b5563;
  --color-text-muted: #6b7280;
  --color-text-faint: #9ca3af;
  --color-primary: #4f6ef7;
  --color-primary-hover: #3d5eea;
  --color-accent: #16b8d4;
  --color-accent-hover: #0fa2bb;
  --color-success: #16a34a;
  --color-danger: #dc2626;
  --color-warning: #eab308;
  --color-focus-ring: rgba(79,110,247,0.35);
  --radius-sm: .375rem;
  --radius: .75rem;
  --radius-lg: 1.2rem;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06);
  --shadow: 0 4px 12px -2px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 28px -4px rgba(0,0,0,.12);
  --transition: 120ms cubic-bezier(.4,0,.2,1);
}

/* Dark mode overrides */
body.dark-mode {
  --color-bg: #12141a;
  --color-bg-alt: #181b22;
  --color-surface: #1d2129;
  --color-surface-alt: #222832;
  --color-border: #2b323d;
  --color-border-strong: #3a4552;
  --color-text: #f2f5f9;
  --color-text-soft: #cfd6e0;
  --color-text-muted: #9aa5b4;
  --color-text-faint: #6b7684;
  --color-primary: #5d7dff;
  --color-primary-hover: #4a68eb;
  --color-accent: #15b3cf;
  --color-accent-hover: #0e9fb8;
  --color-success: #22c55e;
  --color-danger: #f87171;
  --color-warning: #facc15;
  --color-focus-ring: rgba(93,125,255,0.4);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow: 0 4px 16px -2px rgba(0,0,0,.5);
  --shadow-lg: 0 10px 36px -6px rgba(0,0,0,.55);
}

/* ===============================
   BASE
   =============================== */
html { font-size: 15px; }
@media (min-width: 992px){ html { font-size: 16px; } }

body {
  font-family: 'Manrope','Segoe UI',system-ui,Arial,sans-serif;
  background: var(--color-bg);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.45;
  margin: 0;
  min-height: 100vh;
}

main.container {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding-top: 1rem;
}

/* Typography helpers */
.text-soft { color: var(--color-text-soft) !important; }
.text-muted { color: var(--color-text-muted) !important; }
.text-faint { color: var(--color-text-faint) !important; }

/* Headings standardization */
h1, h2, h3, h4, h5, h6 { color: var(--color-text); font-weight: 600; }
h1 { font-size: 2rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }
.display-5 { font-size: 2.5rem; }

/* Links */
a { color: var(--color-primary); text-decoration: none; transition: color var(--transition); }
a:hover, a:focus { color: var(--color-primary-hover); }

/* ===============================
   NAVBAR
   =============================== */
.navbar-ai { 
  background: var(--color-surface); 
  border-bottom: 1px solid var(--color-border); 
  box-shadow: var(--shadow-sm); 
}
body.dark-mode .navbar-ai { 
  background: var(--color-surface); 
  border-bottom-color: var(--color-border);
}
.navbar-brand { color: var(--color-primary) !important; font-weight:700; letter-spacing:.5px; }
.navbar-nav .nav-link { color: var(--color-text-soft); font-weight:500; padding:.6rem 1rem; border-radius: var(--radius-sm); transition: all var(--transition); }
.navbar-nav .nav-link:hover, .navbar-nav .nav-link:focus { color: var(--color-primary); background: var(--color-bg-alt); }
.navbar-nav .nav-link.active { color: var(--color-primary); background: var(--color-bg-alt); }
body.dark-mode .navbar-nav .nav-link { color: var("--color-text-soft"); }
body.dark-mode .navbar-nav .nav-link:hover, body.dark-mode .navbar-nav .nav-link:focus { color: var(--color-primary); background: var(--color-bg-alt); }
body.dark-mode .navbar-nav .nav-link.active { color: var(--color-primary); background: var(--color-bg-alt); }
.navbar-text { color: var(--color-text-soft) !important; }
body.dark-mode .navbar-text { color: var(--color-text-soft) !important; }
body.dark-mode .navbar-toggler { border-color: var(--color-border); }
body.dark-mode .navbar-toggler-icon { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23f2f5f9' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='m4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }

/* ===============================
   COMPONENTS
   =============================== */
.card, .list-group-item, .modal-content { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); color: var(--color-text); }
.list-group-flush > .list-group-item { border-left: none; border-right:none; }
body.dark-mode .card, body.dark-mode .list-group-item, body.dark-mode .modal-content { background: var(--color-surface-alt); }
.card-header { background: var(--color-surface-alt); border-bottom: 1px solid var(--color-border); color: var(--color-text); font-weight: 600; }
body.dark-mode .card-header { background: #262d38; border-bottom-color: var(--color-border-strong); }
.badge { font-weight:500; letter-spacing:.25px; }
.badge.bg-secondary { background: var(--color-accent) !important; }
.badge.unread-count { background: var(--color-primary); }
body.dark-mode .badge.unread-count { background: var(--color-primary); }

/* Unread badge over avatar */
.avatar-wrapper { position: relative; }
.unread-count { position:absolute; top:-4px; right:-4px; background: var(--color-danger); color:#fff; font-size:.65rem; font-weight:600; padding:2px 5px; line-height:1; border-radius:12px; min-width:20px; text-align:center; box-shadow:0 0 0 2px var(--color-surface); }
body.dark-mode .unread-count { box-shadow:0 0 0 2px var(--color-surface-alt); }

/* Buttons */
.btn { border-radius: var(--radius-sm); font-weight:500; letter-spacing:.3px; }
.btn:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--color-focus-ring); }
.btn-primary { background: var(--color-primary); border:1px solid var(--color-primary); box-shadow: var(--shadow-sm); }
.btn-primary:hover, .btn-primary:focus { background: var(--color-primary-hover); border-color: var(--color-primary-hover); transform: translateY(-2px); }
.btn-outline-primary { color: var(--color-primary); border:1px solid var(--color-primary); background: transparent; }
.btn-outline-primary:hover { background: var(--color-primary); color:#fff; }
.btn-outline-accent { color: var(--color-accent); border:1px solid var(--color-accent); }
.btn-outline-accent:hover { background: var(--color-accent); color:#fff; }
.btn-success { background: var(--color-success); border:1px solid var(--color-success); }
.btn-success:hover { filter: brightness(.92); }
.btn-danger { background: var(--color-danger); border:1px solid var(--color-danger); }
.btn-danger:hover { filter: brightness(.9); }
.btn-link { color: var(--color-primary); }
.btn-link:hover { color: var(--color-primary-hover); text-decoration: underline; }

/* Forms */
input.form-control, select.form-select, textarea.form-control { border-radius: var(--radius); border:1px solid var(--color-border); background: var(--color-surface-alt); color: var(--color-text); padding:.65rem .9rem; line-height:1.35; transition: background var(--transition), border-color var(--transition), box-shadow var(--transition); }
input.form-control:focus, select.form-select:focus, textarea.form-control:focus { background: var(--color-surface); border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-focus-ring); outline: none; }
body.dark-mode input.form-control, body.dark-mode select.form-select, body.dark-mode textarea.form-control { background: #1f2530; border-color: var(--color-border); color: var(--color-text); }
body.dark-mode input.form-control:focus { background:#262d38; }
.form-check-input:checked { background-color: var(--color-primary); border-color: var(--color-primary); }
.form-check-input:focus { box-shadow: 0 0 0 0.15rem var(--color-focus-ring); }
body.dark-mode .form-check-input { background-color: var(--color-surface-alt); border-color: var(--color-border); }
body.dark-mode .form-check-label { color: var(--color-text); }

/* Placeholder text fix for all themes - FORCED */
input::placeholder, textarea::placeholder { color: var(--color-text-muted) !important; opacity: 1 !important; }
input::-webkit-input-placeholder, textarea::-webkit-input-placeholder { color: var(--color-text-muted) !important; }
input::-moz-placeholder, textarea::-moz-placeholder { color: var(--color-text-muted) !important; opacity: 1 !important; }
input:-ms-input-placeholder, textarea:-ms-input-placeholder { color: var(--color-text-muted) !important; }
input::-ms-input-placeholder, textarea::-ms-input-placeholder { color: var(--color-text-muted) !important; }

/* Extra override for specific input themes */
.input-theme input::placeholder { color: var(--color-text-muted) !important; }
.input-theme input::-webkit-input-placeholder { color: var(--color-text-muted) !important; }
.input-theme input::-moz-placeholder { color: var(--color-text-muted) !important; opacity: 1 !important; }
.input-theme input:-ms-input-placeholder { color: var(--color-text-muted) !important; }
.input-theme input::-ms-input-placeholder { color: var(--color-text-muted) !important; }
/* Alerts */
.alert { border-radius: var(--radius); border: none; }
.alert-info { background: var(--color-accent) + '20'; color: var(--color-text); border-left: 4px solid var(--color-accent); }
.alert-warning { background: var(--color-warning) + '20'; color: var(--color-text); border-left: 4px solid var(--color-warning); }
.alert-danger { background: var(--color-danger) + '20'; color: var(--color-text); border-left: 4px solid var(--color-danger); }
.alert-success { background: var(--color-success) + '20'; color: var(--color-text); border-left: 4px solid var(--color-success); }
body.dark-mode .alert-info { background: #0e2832; }
body.dark-mode .alert-warning { background: #2a2610; }
body.dark-mode .alert-danger { background: #2a1414; }
body.dark-mode .alert-success { background: #142a18; }

/* Tables */
.table { color: var(--color-text); background: var(--color-surface); }
.table thead th { background: var(--color-surface-alt); border-bottom:2px solid var(--color-border); color: var(--color-text); font-weight:600; }
.table tbody tr { background: var(--color-surface); }
.table tbody td { border-color: var(--color-border); color: var(--color-text); }
.table-hover tbody tr:hover { background: var(--color-bg-alt); }
body.dark-mode .table { background: var(--color-surface-alt); }
body.dark-mode .table thead th { background:#262d38; border-color: var(--color-border-strong); color: var(--color-text); }
body.dark-mode .table tbody tr { background: var(--color-surface-alt); }
body.dark-mode .table tbody td { border-color: var(--color-border); color: var(--color-text); }
body.dark-mode .table-hover tbody tr:hover { background:#252c37; }

/* Table unified theme to sync with CSS vars */
.table-unified { 
  --bs-table-bg: var(--color-surface-alt); 
  --bs-table-color: var(--color-text); 
  --bs-table-border-color: var(--color-border); 
  --bs-table-striped-bg: var(--color-surface); 
  --bs-table-hover-bg: var(--color-bg-alt); 
  --bs-table-striped-color: var(--color-text); 
  --bs-table-hover-color: var(--color-text); 
}
body.dark-mode .table-unified { 
  --bs-table-bg: var(--color-surface-alt); 
  --bs-table-color: var(--color-text); 
  --bs-table-border-color: var(--color-border); 
  --bs-table-striped-bg: #262d38; 
  --bs-table-hover-bg: #252c37; 
  --bs-table-striped-color: var(--color-text); 
  --bs-table-hover-color: var(--color-text); 
}
.table-unified tbody tr { background: var(--bs-table-bg); }
.table-unified tbody tr:hover { background: var(--bs-table-hover-bg); }
.table-unified tbody td, .table-unified thead th { border-color: var(--bs-table-border-color); }

/* Chat filters / inputs themed */
.input-theme .input-group-text { background: var(--color-surface-alt); color: var(--color-text-soft); border-color: var(--color-border); }
.input-theme .form-control { background: var(--color-surface-alt); border-color: var(--color-border); color: var(--color-text); }
.input-theme .form-control:focus { background: var(--color-surface); }
body.dark-mode .input-theme .input-group-text { background: #262d38; color: var(--color-text-soft); border-color: var(--color-border); }
body.dark-mode .input-theme .form-control { background: #262d38; border-color: var(--color-border); color: var(--color-text); }
body.dark-mode .input-theme .form-control:focus { background:#1f2530; }

.filter-bar { background: var(--color-surface-alt); border:1px solid var(--color-border); }
body.dark-mode .filter-bar { background:#262d38; border-color: var(--color-border-strong); }

/* Utility */
.shadow-hover { transition: box-shadow var(--transition), transform var(--transition); }
.shadow-hover:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.divider { height:1px; background: var(--color-border); margin:1.5rem 0; }
body.dark-mode .divider { background: var(--color-border-strong); }
.blinking-dot { width:.6rem; height:.6rem; border-radius:50%; background: var(--color-primary); display:inline-block; animation: blink 1s step-start infinite; }
body.dark-mode .blinking-dot { background: var(--color-accent); }
@keyframes blink { 50% { opacity:0; } }

/* Scrollbars */
::-webkit-scrollbar { width:8px; background: var(--color-bg-alt); }
::-webkit-scrollbar-thumb { background: var(--color-border-strong); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-primary); }
body.dark-mode ::-webkit-scrollbar { background:#1a1f27; }
body.dark-mode ::-webkit-scrollbar-thumb { background:#2f3a46; }
body.dark-mode ::-webkit-scrollbar-thumb:hover { background: var(--color-primary); }

/* Avatar */
.avatar { background: linear-gradient(145deg, var(--color-primary) 0%, #3d56de 45%, var(--color-accent) 100%; }
.avatar-text { color:#ffffff !important; text-shadow:0 1px 2px rgba(0,0,0,.55); font-weight:700; letter-spacing:.5px; }
body.dark-mode .avatar-text { text-shadow:0 1px 2px rgba(0,0,0,.35); }
/* Added visible ring for light theme */
.avatar { border:2px solid var(--color-surface); box-shadow: 0 2px 4px rgba(0,0,0,.18), 0 0 0 2px rgba(255,255,255,.55); }
body.dark-mode .avatar { border:2px solid var(--color-surface-alt); box-shadow:0 2px 6px rgba(0,0,0,.55), 0 0 0 2px rgba(0,0,0,.25); }

/* Chat specific */
.chat-item:hover { background: var(--color-bg-alt); }
body.dark-mode .chat-item:hover { background:#252c37; }

/* Modal */
.modal-content { backdrop-filter: blur(2px); }

/* Code */
code { background: var(--color-surface-alt); padding:.15rem .4rem; border-radius: var(--radius-sm); font-size:.85em; color: var(--color-text); }
body.dark-mode code { background:#262d38; color: var(--color-text); }

/* Lists */
.list-group-item { transition: background var(--transition); }
.list-group-item:hover { background: var(--color-surface-alt); }
body.dark-mode .list-group-item:hover { background:#262d38; }

/* Accessibility */
:focus-visible { outline: 2px solid var(--color-primary); outline-offset:2px; }
body.dark-mode .text-secondary { color: var(--color-text-muted) !important; }
body.dark-mode .text-body { color: var(--color-text) !important; }
body.dark-mode .fw-semibold, body.dark-mode .fw-bold { color: var(--color-text) !important; }
.spinner-border { color: var(--color-primary); }
/* Chat filters / inputs themed */
.input-theme .input-group-text { background: var(--color-surface-alt); color: var(--color-text-soft); border-color: var(--color-border); }
.input-theme .form-control { background: var(--color-surface-alt); border-color: var(--color-border); color: var(--color-text); }
.input-theme .form-control:focus { background: var(--color-surface); }
/* placeholder colors */
.input-theme .form-control::placeholder { color: var(--color-text-faint) !important; opacity: 1; }
body.dark-mode .input-theme .form-control::placeholder { color: var(--color-text-muted) !important; }
body.dark-mode .input-theme .input-group-text { background: #262d38; color: var(--color-text-soft); border-color: var(--color-border); }
body.dark-mode .input-theme .form-control { background: #262d38; border-color: var(--color-border); color: var(--color-text); }
body.dark-mode .input-theme .form-control:focus { background:#1f2530; }

.filter-bar { background: var(--color-surface-alt); border:1px solid var(--color-border); }
body.dark-mode .filter-bar { background:#262d38; border-color: var(--color-border-strong); }

/* Placeholder theming (improved specificity) */
:root { --placeholder-color-light: var(--color-text-faint); --placeholder-color-dark: var(--color-text-muted); }
body.dark-mode { --placeholder-color-light: var(--color-text-muted); }
/* Base generic (kept for other inputs) */
.input-theme .form-control::placeholder { color: var(--placeholder-color-light) !important; opacity: 1; }
/* High-specificity override for chat search */
.input-theme input#chatSearch.form-control::placeholder { color: var(--placeholder-color-light) !important; }
body.dark-mode .input-theme input#chatSearch.form-control::placeholder { color: var(--placeholder-color-dark) !important; }
/* Vendor prefixed with specificity */
.input-theme input#chatSearch.form-control::-webkit-input-placeholder { color: var(--placeholder-color-light) !important; }
body.dark-mode .input-theme input#chatSearch.form-control::-webkit-input-placeholder { color: var(--placeholder-color-dark) !important; }
.input-theme input#chatSearch.form-control::-moz-placeholder { color: var(--placeholder-color-light) !important; }
body.dark-mode .input-theme input#chatSearch.form-control::-moz-placeholder { color: var(--placeholder-color-dark) !important; }
.input-theme input#chatSearch.form-control:-ms-input-placeholder { color: var(--placeholder-color-light) !important; }
body.dark-mode .input-theme input#chatSearch.form-control:-ms-input-placeholder { color: var(--placeholder-color-dark) !important; }
.input-theme input#chatSearch.form-control::-ms-input-placeholder { color: var(--placeholder-color-light) !important; }
body.dark-mode .input-theme input#chatSearch.form-control::-ms-input-placeholder { color: var(--placeholder-color-dark) !important; }
/* Specific override for chat search input text & placeholder */
.chat-search-input { color: var(--color-text) !important; }
.chat-search-input::placeholder { color: var(--color-text-faint) !important; }
body.dark-mode .chat-search-input { color: var(--color-text) !important; }
body.dark-mode .chat-search-input::placeholder { color: var(--color-text-muted) !important; }
/* Login page specific styles */
.login-wrapper {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);
  position: relative;
}
.login-wrapper::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(circle at 20% 80%, rgba(255,255,255,0.1) 0%, transparent 50%),
              radial-gradient(circle at 80% 20%, rgba(255,255,255,0.08) 0%, transparent 50%);
}
.login-card {
  position: relative;
  z-index: 1;
  max-width: 400px;
  width: 100%;
  border-radius: 1.5rem;
  border: none;
  background: var(--color-surface);
  backdrop-filter: blur(10px);
}
body.dark-mode .login-card {
  background: var(--color-surface);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

.login-logo .logo-icon {
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  border-radius: 18px;
  font-size: 1.6rem;
  color: white;
  box-shadow: 0 8px 28px rgba(79,110,247,0.3);
  position: relative;
  overflow: hidden;
}
.login-logo .logo-icon::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.1), transparent);
  transform: rotate(45deg);
  animation: shimmer 3s infinite;
}
@keyframes shimmer {
  0% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
  50% { transform: translateX(100%) translateY(100%) rotate(45deg); }
  100% { transform: translateX(-100%) translateY(-100%) rotate(45deg); }
}

body.dark-mode .login-wrapper {
  background: linear-gradient(135deg, #1a1d2e 0%, #16213e 100%);
}

  /* ===============================
     FEEDBACK SYSTEM
     =============================== */

  #feedbackBtn {
    border: 2px solid var(--color-border-strong);
  }

  body.dark-mode #feedbackBtn {
    border-color: var(--color-border);
  }

  .feedback-form {
  width: 340px;
  background: var(--color-surface);
  border: 2px solid var(--color-border-strong);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  animation: feedbackSlideIn 0.3s ease-out;
  overflow: hidden;
  backdrop-filter: blur(8px);
  z-index: 2000;
}

body.dark-mode .feedback-form {
  background: var(--color-surface);
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(8px);
}

.feedback-header {
  padding: 1.5rem 1.5rem 1rem;
  background: var(--color-surface-alt);
  border-bottom: 2px solid var(--color-border);
}

body.dark-mode .feedback-header {
  background: var(--color-surface-alt);
  border-bottom-color: var(--color-border);
}

.feedback-body {
  padding: 1.5rem;
  background: var(--color-surface);
}

body.dark-mode .feedback-body {
  background: var(--color-surface);
}

.feedback-success {
  padding: 2.5rem 1.5rem;
  background: var(--color-surface);
}

body.dark-mode .feedback-success {
  background: var(--color-surface);
}

.feedback-form .form-label {
  color: var(--color-text);
  margin-bottom: 0.75rem;
  font-weight: 500;
  font-size: 0.9rem;
}

.feedback-form .form-control {
  border-radius: var(--radius);
  border: 2px solid var(--color-border);
  background: var(--color-surface-alt);
  color: var(--color-text);
  font-size: 0.9rem;
  padding: 0.75rem;
  transition: all var(--transition);
  margin-bottom: 0.5rem;
}

.feedback-form .form-control:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-focus-ring);
  background: var(--color-surface);
}

.feedback-form .form-text {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  margin-top: 0.25rem;
  margin-bottom: 1rem;
}

body.dark-mode .feedback-form .form-control {
  background: var(--color-surface-alt);
  border-color: var(--color-border);
  color: var(--color-text);
}

body.dark-mode .feedback-form .form-control:focus {
  background: var(--color-surface);
  border-color: var(--color-primary);
}

.feedback-form .btn {
  padding: 0.75rem 1.25rem;
  font-weight: 500;
  border-radius: var(--radius);
  transition: all var(--transition);
  border: 2px solid transparent;
  margin-top: 0.5rem;
}

.feedback-form .btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.feedback-form .btn-primary:hover {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  transform: translateY(-1px);
}

.feedback-form .btn-outline-secondary {
  color: var(--color-text-soft);
  border-color: var(--color-border);
  background: transparent;
}

.feedback-form .btn-outline-secondary:hover {
  background: var(--color-surface-alt);
  border-color: var(--color-border-strong);
  color: var(--color-text);
}

.feedback-form .mb-3 {
  margin-bottom: 1.5rem !important;
}

.feedback-form .d-flex.gap-2 {
  gap: 0.75rem !important;
  margin-top: 1rem;
}

/* Backdrop overlay for better visibility */
.feedback-form::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.1);
  z-index: -1;
  pointer-events: none;
}

body.dark-mode .feedback-form::before {
  background: rgba(0, 0, 0, 0.3);
}

@keyframes feedbackSlideIn {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes feedbackSlideOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateY(20px) scale(0.95);
  }
}

.feedback-form.hiding {
  animation: feedbackSlideOut 0.3s ease-in;
}

@media (max-width: 768px) {
  .feedback-form {
    width: calc(100vw - 2rem);
    right: 1rem !important;
    left: 1rem !important;
  }
  
  .feedback-header {
    padding: 1.25rem 1.25rem 0.75rem;
  }
  
  .feedback-body {
    padding: 1.25rem;
  }
  
  .feedback-success {
    padding: 2rem 1.25rem;
  }
}
