/* Neumorphism Design System for Sea-Go */

:root {
  /* Neumorphism Color Palette */
  --neu-bg: #e0e5ec;
  --neu-bg-dark: #d1d9e6;
  --neu-bg-light: #f9f9f9;
  --neu-shadow-dark: #a3b1c6;
  --neu-shadow-light: #ffffff;
  --neu-text: #4a5568;
  --neu-text-light: #718096;
  --neu-text-muted: #a0aec0;
  --neu-primary: #667eea;
  --neu-primary-dark: #5a67d8;
  --neu-primary-rgb: 102, 126, 234;
  --neu-secondary: #764ba2;
  --neu-success: #48bb78;
  --neu-warning: #ed8936;
  --neu-danger: #f56565;
  --neu-info: #4299e1;
  --neu-border: #cbd5e0;

  /* Neumorphism Shadows */
  --neu-shadow-inset: inset 6px 6px 12px var(--neu-shadow-dark),
    inset -6px -6px 12px var(--neu-shadow-light);
  --neu-shadow-outset: 6px 6px 12px var(--neu-shadow-dark),
    -6px -6px 12px var(--neu-shadow-light);
  --neu-shadow-pressed: inset 3px 3px 6px var(--neu-shadow-dark),
    inset -3px -3px 6px var(--neu-shadow-light);
  --neu-shadow-hover: 8px 8px 16px var(--neu-shadow-dark),
    -8px -8px 16px var(--neu-shadow-light);
  --neu-shadow-small: 3px 3px 6px var(--neu-shadow-dark),
    -3px -3px 6px var(--neu-shadow-light);
}

/* Base Styles */
body {
  background: var(--neu-bg);
  color: var(--neu-text);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    sans-serif;
  line-height: 1.6;
  margin: 0;
  padding: 0;
}

/* Text Utilities */
.neu-text-primary {
  color: var(--neu-primary) !important;
}

.neu-text-muted {
  color: var(--neu-text-muted) !important;
}

/* Neumorphic Container */
.neu-container {
  background: var(--neu-bg);
  border-radius: 20px;
  box-shadow: var(--neu-shadow-outset);
  padding: 2rem;
  margin: 1rem;
  transition: all 0.3s ease;
}

.neu-container:hover {
  box-shadow: var(--neu-shadow-hover);
}

/* Neumorphic Cards */
.neu-card {
  background: var(--neu-bg);
  border-radius: 16px;
  box-shadow: var(--neu-shadow-outset);
  padding: 0;
  margin: 1rem 0;
  border: none;
  transition: all 0.3s ease;
  overflow: hidden;
}

.neu-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--neu-shadow-hover);
}

.neu-card-header {
  background: var(--neu-bg-dark);
  padding: 1rem 1.5rem;
  border-bottom: 1px solid rgba(163, 177, 198, 0.1);
  margin: 0;
}

.neu-card-header h6 {
  margin: 0;
  font-weight: 600;
}

.neu-card-body {
  background: var(--neu-bg);
  padding: 1.5rem;
}

.neu-card-small {
  background: var(--neu-bg);
  border-radius: 12px;
  box-shadow: var(--neu-shadow-small);
  padding: 1rem;
  margin: 0.5rem 0;
  border: none;
  transition: all 0.3s ease;
}

/* Neumorphic Buttons */
.neu-btn {
  background: var(--neu-bg);
  border: none;
  border-radius: 12px;
  box-shadow: var(--neu-shadow-outset);
  color: var(--neu-text);
  cursor: pointer !important;
  font-weight: 600;
  padding: 12px 24px;
  text-decoration: none;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  pointer-events: auto !important;
}

/* Ensure all buttons have proper cursor */
button,
.btn,
.neu-btn,
input[type="button"],
input[type="submit"],
input[type="reset"] {
  cursor: pointer !important;
  pointer-events: auto !important;
}

/* Ensure close buttons work */
.btn-close {
  cursor: pointer !important;
  pointer-events: auto !important;
}

.neu-btn:hover {
  box-shadow: var(--neu-shadow-hover);
  transform: translateY(-1px);
  color: var(--neu-text);
  text-decoration: none;
}

.neu-btn:active {
  box-shadow: var(--neu-shadow-pressed);
  transform: translateY(0);
}

.neu-btn:focus {
  outline: none;
  box-shadow: var(--neu-shadow-outset), 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* Button Variants */
.neu-btn-primary {
  background: linear-gradient(
    145deg,
    var(--neu-primary),
    var(--neu-primary-dark)
  );
  color: white;
  box-shadow: 6px 6px 12px rgba(102, 126, 234, 0.2),
    -6px -6px 12px rgba(255, 255, 255, 0.8);
}

.neu-btn-primary:hover {
  box-shadow: 8px 8px 16px rgba(102, 126, 234, 0.3),
    -8px -8px 16px rgba(255, 255, 255, 0.9);
  color: white;
}

.neu-btn-primary:active {
  box-shadow: inset 3px 3px 6px rgba(102, 126, 234, 0.4),
    inset -3px -3px 6px rgba(255, 255, 255, 0.6);
  transform: translateY(0);
  color: white;
}

.neu-btn-success {
  background: linear-gradient(145deg, var(--neu-success), #38a169);
  color: white;
  box-shadow: 6px 6px 12px rgba(72, 187, 120, 0.2),
    -6px -6px 12px rgba(255, 255, 255, 0.8);
}

.neu-btn-success:active {
  box-shadow: inset 3px 3px 6px rgba(72, 187, 120, 0.4),
    inset -3px -3px 6px rgba(255, 255, 255, 0.6);
  transform: translateY(0);
  color: white;
}

.neu-btn-danger {
  background: linear-gradient(145deg, var(--neu-danger), #e53e3e);
  color: white;
  box-shadow: 6px 6px 12px rgba(245, 101, 101, 0.2),
    -6px -6px 12px rgba(255, 255, 255, 0.8);
}

.neu-btn-danger:active {
  box-shadow: inset 3px 3px 6px rgba(245, 101, 101, 0.4),
    inset -3px -3px 6px rgba(255, 255, 255, 0.6);
  transform: translateY(0);
  color: white;
}

.neu-btn-warning {
  background: linear-gradient(145deg, var(--neu-warning), #dd6b20);
  color: white;
  box-shadow: 6px 6px 12px rgba(237, 137, 54, 0.2),
    -6px -6px 12px rgba(255, 255, 255, 0.8);
}

.neu-btn-warning:active {
  box-shadow: inset 3px 3px 6px rgba(237, 137, 54, 0.4),
    inset -3px -3px 6px rgba(255, 255, 255, 0.6);
  transform: translateY(0);
  color: white;
}

.neu-btn-info {
  background: linear-gradient(145deg, var(--neu-info), #3182ce);
  color: white;
  box-shadow: 6px 6px 12px rgba(66, 153, 225, 0.2),
    -6px -6px 12px rgba(255, 255, 255, 0.8);
}

.neu-btn-info:active {
  box-shadow: inset 3px 3px 6px rgba(66, 153, 225, 0.4),
    inset -3px -3px 6px rgba(255, 255, 255, 0.6);
  transform: translateY(0);
  color: white;
}

/* Small Buttons */
.neu-btn-sm {
  padding: 8px 12px;
  font-size: 12px;
  border-radius: 8px;
  min-width: 40px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 2px;
}

.neu-btn-lg {
  padding: 16px 32px;
  font-size: 16px;
  border-radius: 16px;
}

/* Neumorphic Form Controls */
.neu-input,
.neu-form-control {
  background: var(--neu-bg);
  border: none;
  border-radius: 12px;
  box-shadow: var(--neu-shadow-inset);
  color: var(--neu-text);
  font-size: 14px;
  padding: 12px 16px;
  width: 100%;
  transition: all 0.3s ease;
  box-sizing: border-box;
  cursor: text;
}

.neu-input:focus,
.neu-form-control:focus {
  outline: none;
  box-shadow: var(--neu-shadow-inset), 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.neu-input::placeholder,
.neu-form-control::placeholder {
  color: var(--neu-text-light);
}

.neu-form-label {
  color: var(--neu-text);
  font-weight: 500;
  margin-bottom: 8px;
  display: block;
  font-size: 14px;
}

.neu-select,
select.neu-form-control {
  background: var(--neu-bg);
  border: none;
  border-radius: 12px;
  box-shadow: var(--neu-shadow-inset);
  color: var(--neu-text);
  font-size: 14px;
  padding: 12px 16px;
  width: 100%;
  transition: all 0.3s ease;
  cursor: pointer;
}

/* Override cursor for select elements */
select.neu-form-control,
.neu-select {
  cursor: pointer !important;
}

/* Override cursor for text inputs */
input[type="text"].neu-form-control,
input[type="email"].neu-form-control,
input[type="password"].neu-form-control,
input[type="number"].neu-form-control,
textarea.neu-form-control {
  cursor: text !important;
}

.neu-select:focus,
select.neu-form-control:focus {
  outline: none;
  box-shadow: var(--neu-shadow-inset), 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.neu-textarea {
  background: var(--neu-bg);
  border: none;
  border-radius: 12px;
  box-shadow: var(--neu-shadow-inset);
  color: var(--neu-text);
  font-size: 14px;
  padding: 12px 16px;
  width: 100%;
  min-height: 100px;
  resize: vertical;
  transition: all 0.3s ease;
  font-family: inherit;
}

.neu-textarea:focus {
  outline: none;
  box-shadow: var(--neu-shadow-inset), 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* Make textarea work with neu-form-control class */
textarea.neu-form-control {
  min-height: 100px;
  resize: vertical;
  font-family: inherit;
}

/* Neumorphic Navigation */
.neu-navbar {
  background: var(--neu-bg);
  box-shadow: 0 2px 20px rgba(163, 177, 198, 0.3);
  padding: 1rem 0;
  position: sticky;
  top: 0;
  z-index: 1000;
}

.neu-nav-brand {
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--neu-primary);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
}

.neu-nav-link {
  color: var(--neu-text);
  text-decoration: none;
  padding: 8px 16px;
  border-radius: 8px;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}

.neu-nav-link:hover {
  background: var(--neu-bg-dark);
  box-shadow: var(--neu-shadow-small);
  color: var(--neu-text);
  text-decoration: none;
}

/* Neumorphic Sidebar */
.neu-sidebar {
  background: var(--neu-bg);
  box-shadow: 2px 0 20px rgba(163, 177, 198, 0.2);
  min-height: 100vh;
  padding: 2rem 1rem;
}

.neu-sidebar .nav-link {
  color: var(--neu-text);
  padding: 12px 16px;
  margin: 4px 0;
  border-radius: 12px;
  transition: all 0.3s ease;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
}

.neu-sidebar .nav-link:hover {
  background: var(--neu-bg-dark);
  box-shadow: var(--neu-shadow-small);
  color: var(--neu-text);
  text-decoration: none;
}

.neu-sidebar .nav-link.active {
  background: linear-gradient(
    145deg,
    var(--neu-primary),
    var(--neu-primary-dark)
  );
  color: white;
  box-shadow: var(--neu-shadow-small);
}

/* Neumorphic Tables */
.neu-table {
  background: var(--neu-bg);
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0;
}

.neu-table th {
  background: var(--neu-bg-dark);
  color: var(--neu-text);
  font-weight: 600;
  padding: 16px;
  text-align: left;
  border: none;
  position: sticky;
  top: 0;
  z-index: 10;
}

.neu-table th:first-child {
  border-top-left-radius: 0;
}

.neu-table th:last-child {
  border-top-right-radius: 0;
}

.neu-table td {
  padding: 12px 16px;
  border: none;
  border-bottom: 1px solid rgba(163, 177, 198, 0.1);
  background: var(--neu-bg);
  vertical-align: middle;
}

.neu-table tr:last-child td {
  border-bottom: none;
}

.neu-table tr:hover td {
  background: rgba(102, 126, 234, 0.05);
}

.table-responsive {
  border-radius: 0;
  box-shadow: none;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Neumorphic Alerts */
.neu-alert {
  border-radius: 12px;
  padding: 16px;
  margin: 16px 0;
  border: none;
  display: flex;
  align-items: center;
  gap: 10px;
}

.neu-alert-success {
  background: linear-gradient(145deg, #f0fff4, #e6fffa);
  color: #22543d;
  box-shadow: 3px 3px 6px rgba(72, 187, 120, 0.1),
    -3px -3px 6px rgba(255, 255, 255, 0.8);
}

.neu-alert-danger {
  background: linear-gradient(145deg, #fff5f5, #fed7d7);
  color: #742a2a;
  box-shadow: 3px 3px 6px rgba(245, 101, 101, 0.1),
    -3px -3px 6px rgba(255, 255, 255, 0.8);
}

.neu-alert-warning {
  background: linear-gradient(145deg, #fffaf0, #feebc8);
  color: #744210;
  box-shadow: 3px 3px 6px rgba(237, 137, 54, 0.1),
    -3px -3px 6px rgba(255, 255, 255, 0.8);
}

.neu-alert-info {
  background: linear-gradient(145deg, #ebf8ff, #bee3f8);
  color: #2a4365;
  box-shadow: 3px 3px 6px rgba(66, 153, 225, 0.1),
    -3px -3px 6px rgba(255, 255, 255, 0.8);
}

/* Neumorphic Badges */
.neu-badge {
  background: var(--neu-bg);
  border-radius: 20px;
  box-shadow: var(--neu-shadow-small);
  color: var(--neu-text);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 12px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.neu-badge-primary {
  background: linear-gradient(
    145deg,
    var(--neu-primary),
    var(--neu-primary-dark)
  );
  color: white;
}

.neu-badge-success {
  background: linear-gradient(145deg, var(--neu-success), #38a169);
  color: white;
}

.neu-badge-danger {
  background: linear-gradient(145deg, var(--neu-danger), #e53e3e);
  color: white;
}

/* Neumorphic Modal */
.modal {
  z-index: 1055 !important;
}

.modal-backdrop {
  z-index: 1050 !important;
  background-color: rgba(224, 229, 236, 0.8) !important;
  backdrop-filter: blur(10px);
}

.neu-modal {
  background: rgba(224, 229, 236, 0.8);
  backdrop-filter: blur(10px);
}

.neu-modal-content {
  background: var(--neu-bg);
  border-radius: 20px;
  box-shadow: var(--neu-shadow-outset);
  border: none;
  position: relative;
  z-index: 1060;
}

.neu-modal-header {
  background: var(--neu-bg);
  border-bottom: 1px solid rgba(163, 177, 198, 0.2);
  border-radius: 20px 20px 0 0;
  padding: 1.5rem;
}

.neu-modal-body {
  padding: 1.5rem;
}

.neu-modal-footer {
  background: var(--neu-bg);
  border-top: 1px solid rgba(163, 177, 198, 0.2);
  border-radius: 0 0 20px 20px;
  padding: 1.5rem;
}

/* Ensure modal elements are clickable */
.modal-dialog {
  pointer-events: auto;
}

.modal-content {
  pointer-events: auto;
}

.neu-form-control,
.neu-btn {
  pointer-events: auto !important;
  position: relative;
  z-index: 1;
  cursor: pointer;
}

.neu-form-control:focus {
  pointer-events: auto !important;
  cursor: text;
}

/* Fix for modal input and button interactions */
.modal .neu-btn {
  pointer-events: auto !important;
  cursor: pointer !important;
  user-select: none;
}

.modal .neu-form-control {
  pointer-events: auto !important;
  cursor: text !important;
  user-select: text;
}

.modal textarea.neu-form-control {
  resize: vertical;
  cursor: text !important;
}

.modal select.neu-form-control {
  cursor: pointer !important;
}

/* Ensure all interactive elements in modal work */
.modal input,
.modal textarea,
.modal select,
.modal button {
  pointer-events: auto !important;
  position: relative;
  z-index: 2;
}

.modal .btn-close {
  pointer-events: auto !important;
  cursor: pointer !important;
}

/* File input styling */
input[type="file"].neu-form-control {
  padding: 8px 12px;
  cursor: pointer;
  background: var(--neu-bg);
  border: 1px solid rgba(163, 177, 198, 0.3);
  border-radius: 12px;
  box-shadow: var(--neu-shadow-inset);
  transition: all 0.3s ease;
}

input[type="file"].neu-form-control:hover {
  box-shadow: var(--neu-shadow-hover);
}

input[type="file"].neu-form-control:focus {
  outline: none;
  box-shadow: var(--neu-shadow-inset), 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.modal input[type="file"].neu-form-control {
  pointer-events: auto !important;
  cursor: pointer !important;
}

/* Neumorphic Product Cards */
.neu-product-card {
  background: var(--neu-bg);
  border-radius: 20px;
  box-shadow: var(--neu-shadow-outset);
  padding: 1.5rem;
  text-align: center;
  transition: all 0.3s ease;
  border: none;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.neu-product-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--neu-shadow-hover);
}

.neu-product-image {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 0.75rem;
  box-shadow: var(--neu-shadow-small);
}

/* Ensure consistent spacing below product image across layouts */
.neu-product-image-container {
  margin-bottom: 0.75rem;
}

.neu-product-category {
  margin-bottom: 0.5rem;
  margin-top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.neu-product-category small {
  background: var(--neu-bg-dark);
  padding: 0.3rem 0.6rem;
  border-radius: 10px;
  font-size: 0.75rem;
  box-shadow: var(--neu-shadow-small);
  color: var(--neu-text-light);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  white-space: nowrap;
  line-height: 1;
}

.neu-product-store {
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.neu-product-store small {
  background: var(--neu-bg-dark);
  padding: 0.3rem 0.6rem;
  border-radius: 10px;
  font-size: 0.75rem;
  box-shadow: var(--neu-shadow-small);
  color: var(--neu-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  white-space: nowrap;
  line-height: 1;
}

.neu-product-title {
  color: var(--neu-text);
  font-weight: 600;
  margin-bottom: 0.5rem;
  font-size: 1.1rem;
}

.neu-product-description {
  color: var(--neu-text-light);
  font-size: 0.9rem;
  margin-bottom: 1rem;
  flex-grow: 1;
  line-height: 1.4;
}

.neu-product-price {
  color: var(--neu-primary);
  font-weight: 700;
  font-size: 1.2rem;
  margin-bottom: 1rem;
}

/* Neumorphic Statistics Cards */
.neu-stat-card {
  background: var(--neu-bg);
  border-radius: 16px;
  box-shadow: var(--neu-shadow-outset);
  padding: 1.5rem;
  text-align: center;
  transition: all 0.3s ease;
  border: none;
}

.neu-stat-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--neu-shadow-hover);
}

.neu-stat-icon {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  color: var(--neu-primary);
}

.neu-stat-number {
  font-size: 2rem;
  font-weight: 700;
  color: var(--neu-text);
  margin-bottom: 0.25rem;
}

.neu-stat-label {
  color: var(--neu-text-light);
  font-size: 0.9rem;
  font-weight: 500;
}

/* Responsive Design */
@media (max-width: 768px) {
  .neu-container {
    margin: 0.5rem;
    padding: 1rem;
    border-radius: 16px;
  }

  .neu-card {
    padding: 1rem;
    border-radius: 12px;
  }

  .neu-btn {
    padding: 10px 20px;
    font-size: 13px;
  }

  .neu-sidebar {
    padding: 1rem 0.5rem;
  }
}

/* Utility Classes */
.neu-shadow-inset {
  box-shadow: var(--neu-shadow-inset) !important;
}

.neu-shadow-outset {
  box-shadow: var(--neu-shadow-outset) !important;
}

.neu-shadow-small {
  box-shadow: var(--neu-shadow-small) !important;
}

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

.neu-text-muted {
  color: var(--neu-text-light) !important;
}

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

.neu-rounded {
  border-radius: 12px !important;
}

.neu-rounded-lg {
  border-radius: 20px !important;
}
