/*!
 * Base styles and CSS reset
 * File: base.css
 * Category: base
 * Generated: 2025-12-16 22:01:11
 * Updated: 2025-12-31 (Added auth page reset)
 * Size: 128 bytes
 * Lines: 14
 */


*,
::after,
::before {
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

/* Auth page specific reset - removes white border */
body.auth-page,
body[data-page="auth"] {
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden;
}

/* Focus states for better accessibility */
*:focus {
    outline: 2px solid var(--theme-primary);
    outline-offset: 2px;
}

*:focus:not(:focus-visible) {
    outline: none;
}

*:focus-visible {
    outline: 2px solid var(--theme-primary);
    outline-offset: 2px;
}

/* HTMX Indicator Styles */
.htmx-indicator {
    opacity: 0;
    transition: opacity 200ms ease-in;
}
.htmx-request .htmx-indicator {
    opacity: 1;
}
.htmx-request.htmx-indicator {
    opacity: 1;
}

/* ============ CSS VARIABLES ============ */
:root {
  /* Base button */
  --button-bg: var(--color-button-primary-bg);
  --button-border: var(--color-button-primary-border);
  --button-text: var(--color-button-primary-text);
  --button-hover-bg: var(--color-button-primary-hover);
  --button-hover-border: var(--color-button-primary-hover);
  --button-active-bg: var(--color-button-primary-active);
  
  /* Secondary button */
  --button-secondary-bg: var(--color-button-secondary-bg);
  --button-secondary-border: var(--color-button-secondary-border);
  --button-secondary-text: var(--color-button-secondary-text);
  --button-secondary-hover: var(--color-button-secondary-hover);
  
  /* Accent button */
  --button-accent-bg: var(--color-button-accent-bg);
  --button-accent-border: var(--color-button-accent-border);
  --button-accent-text: var(--color-button-accent-text);
  --button-accent-hover: var(--color-button-accent-hover);
  
  /* White buttons */
  --button-white-bg: var(--color-white);
  --button-white-border: var(--theme-border-primary);
  --button-white-text: var(--theme-text-primary);
  --button-white-hover-bg: var(--color-bg-secondary);
  --button-white-hover-border: var(--theme-border-secondary);
  
  /* Outline buttons */
  --button-outline-primary-border: var(--theme-primary);
  --button-outline-primary-text: var(--theme-primary);
  --button-outline-primary-hover-bg: var(--theme-primary);
  --button-outline-primary-hover-text: var(--color-text-on-primary);
  
  --button-outline-secondary-border: var(--theme-secondary);
  --button-outline-secondary-text: var(--theme-secondary);
  --button-outline-secondary-hover-bg: var(--theme-secondary);
  --button-outline-secondary-hover-text: var(--color-text-on-secondary);
  
  --button-outline-dark-border: var(--color-navy-800);
  --button-outline-dark-text: var(--color-navy-800);
  --button-outline-dark-hover-bg: var(--color-navy-800);
  
  /* Circle buttons */
  --button-circle-bg: var(--button-circle-bg);
  --button-circle-border: var(--button-circle-border);
  --button-circle-text: var(--button-circle-text);
  --button-circle-hover-bg: var(--button-circle-hover-bg);
  
  --button-circle-white-bg: var(--button-circle-white-bg);
  --button-circle-white-border: var(--button-circle-white-border);
  --button-circle-white-text: var(--button-circle-white-text);
  --button-circle-white-hover-bg: var(--button-circle-white-hover-bg);
  --button-circle-white-hover-border: var(--button-circle-white-hover-border);
  --button-circle-white-hover-text: var(--button-circle-white-hover-text);
  
  /* Loading spinner */
  --button-loading-border: var(--color-white-opacity-30);
  --button-loading-spinner: var(--color-white);
}

/* ============ BASE BUTTON STYLES ============ */
.button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--button-bg);
  border: 1px solid var(--button-border);
  padding: 12px 24px;
  color: var(--button-text);
  font: 500 0.875em "Poppins", sans-serif;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  text-decoration: none;
  gap: 8px;
  line-height: 1.5;
  user-select: none;
  vertical-align: middle;
  white-space: nowrap;
}

.button i {
  font-size: 15px;
  transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.button:hover,
.button:focus {
  background: var(--button-hover-bg);
  border-color: var(--button-hover-border);
  color: var(--button-text);
  transform: translateY(-2px);
  box-shadow: var(--theme-shadow-md);
}

.button:active {
  background: var(--button-active-bg);
  transform: translateY(0);
  box-shadow: var(--theme-shadow-sm);
}

/* ============ BUTTON SIZES ============ */
.button-sm {
  padding: 10px 20px;
  font-size: 0.813em;
  gap: 6px;
}

.button-sm i {
  font-size: 14px;
}

.button-md {
  padding: 14px 28px;
  font-size: 0.875em;
  gap: 8px;
}

.button-lg {
  padding: 16px 32px;
  font-size: 1em;
  gap: 10px;
}

.button-lg i {
  font-size: 16px;
}

.button-xl {
  padding: 18px 36px;
  font-size: 1.063em;
  gap: 12px;
}

.button-xl i {
  font-size: 18px;
}

/* ============ BUTTON VARIANTS ============ */
/* Primary Button */
.button-primary {
  background: var(--button-bg);
  border-color: var(--button-border);
  color: var(--button-text);
}

.button-primary:hover,
.button-primary:focus {
  background: var(--button-hover-bg);
  border-color: var(--button-hover-border);
}

/* Secondary Button */
.button-secondary {
  background: var(--button-secondary-bg);
  border-color: var(--button-secondary-border);
  color: var(--button-secondary-text);
}

.button-secondary:hover,
.button-secondary:focus {
  background: var(--button-secondary-hover);
  border-color: var(--button-secondary-border);
}

/* Accent Button */
.button-accent {
  background: var(--button-accent-bg);
  border-color: var(--button-accent-border);
  color: var(--button-accent-text);
}

.button-accent:hover,
.button-accent:focus {
  background: var(--button-accent-hover);
  border-color: var(--button-accent-hover);
}

/* White Buttons */
.button-white {
  background: var(--button-white-bg);
  border: 1px solid var(--button-white-border);
  color: var(--button-white-text);
}

.button-white:hover,
.button-white:focus {
  background: var(--button-white-hover-bg);
  border-color: var(--button-white-hover-border);
  color: var(--button-white-text);
}

.button-white-2 {
  background: var(--color-white-opacity-10);
  border: 1px solid var(--color-white-opacity-20);
  color: var(--color-white);
}

.button-white-2:hover,
.button-white-2:focus {
  background: var(--color-white-opacity-15);
  border-color: var(--color-white-opacity-30);
  color: var(--color-white);
}

/* Outline Buttons */
.button-outline {
  background: transparent;
}

.button-outline-primary {
  background: transparent;
  border: 2px solid var(--button-outline-primary-border);
  color: var(--button-outline-primary-text);
}

.button-outline-primary:hover,
.button-outline-primary:focus {
  background: var(--button-outline-primary-hover-bg);
  color: var(--button-outline-primary-hover-text);
}

.button-outline-secondary {
  background: transparent;
  border: 2px solid var(--button-outline-secondary-border);
  color: var(--button-outline-secondary-text);
}

.button-outline-secondary:hover,
.button-outline-secondary:focus {
  background: var(--button-outline-secondary-hover-bg);
  color: var(--button-outline-secondary-hover-text);
}

.button-outline-dark {
  background: transparent;
  border: 2px solid var(--button-outline-dark-border);
  color: var(--button-outline-dark-text);
}

.button-outline-dark:hover,
.button-outline-dark:focus {
  background: var(--button-outline-dark-hover-bg);
  border-color: transparent;
  color: var(--color-white);
}

/* Gradient Buttons */
.button-gradient-1 {
  background: var(--gradient-button-primary);
  border: 0;
  color: var(--color-text-on-accent);
  box-shadow: 0 4px 15px var(--color-shadow-gradient-primary);
}

.button-gradient-2 {
  background: var(--gradient-button-secondary);
  border: 0;
  color: var(--color-white);
  box-shadow: 0 4px 15px var(--color-shadow-gradient-secondary);
}

.button-gradient-success {
  background: var(--gradient-button-success);
  border: 0;
  color: var(--color-white);
  box-shadow: 0 4px 15px var(--color-shadow-gradient-success);
}

.button-gradient-warning {
  background: var(--gradient-button-warning);
  border: 0;
  color: var(--color-white);
  box-shadow: 0 4px 15px var(--color-shadow-gradient-warning);
}

.button-gradient-error {
  background: var(--gradient-button-error);
  border: 0;
  color: var(--color-white);
  box-shadow: 0 4px 15px var(--color-shadow-gradient-error);
}

.button-gradient-info {
  background: var(--gradient-button-info);
  border: 0;
  color: var(--color-white);
  box-shadow: 0 4px 15px var(--color-shadow-gradient-info);
}

[class*='button-gradient']:hover,
[class*='button-gradient']:focus {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px var(--color-shadow-medium);
  opacity: 0.95;
}

/* Status Buttons */
.button-success {
  background: var(--color-success);
  border-color: var(--color-success);
  color: var(--color-white);
}

.button-success:hover,
.button-success:focus {
  background: var(--color-success-dark);
  border-color: var(--color-success-dark);
}

.button-warning {
  background: var(--color-warning);
  border-color: var(--color-warning);
  color: var(--color-white);
}

.button-warning:hover,
.button-warning:focus {
  background: var(--color-warning-dark);
  border-color: var(--color-warning-dark);
}

.button-error {
  background: var(--color-error);
  border-color: var(--color-error);
  color: var(--color-white);
}

.button-error:hover,
.button-error:focus {
  background: var(--color-error-dark);
  border-color: var(--color-error-dark);
}

.button-info {
  background: var(--color-info);
  border-color: var(--color-info);
  color: var(--color-white);
}

.button-info:hover,
.button-info:focus {
  background: var(--color-info-dark);
  border-color: var(--color-info-dark);
}

/* ============ CIRCLE BUTTONS ============ */
.button-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--button-circle-bg);
  border: 1px solid var(--button-circle-border);
  border-radius: 50%;
  color: var(--button-circle-text);
  text-align: center;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  width: 48px;
  height: 48px;
  padding: 0;
  flex-shrink: 0;
}

.button-circle:hover {
  background: var(--button-circle-hover-bg);
  border-color: var(--button-circle-hover-bg);
  color: var(--button-circle-text);
  transform: translateY(-2px);
  box-shadow: var(--theme-shadow-md);
}

.button-circle.button-circle-white {
  background: var(--button-circle-white-bg);
  border: 1px solid var(--button-circle-white-border);
  color: var(--button-circle-white-text);
}

.button-circle.button-circle-white:hover,
.button-circle.button-circle-white:focus {
  background: var(--button-circle-white-hover-bg);
  border-color: var(--button-circle-white-hover-border);
  color: var(--button-circle-white-hover-text);
}

.button-circle-sm {
  width: 40px;
  height: 40px;
  font-size: 0.813em;
}

.button-circle-md {
  width: 48px;
  height: 48px;
  font-size: 0.875em;
}

.button-circle-lg {
  width: 56px;
  height: 56px;
  font-size: 1em;
}

.button-circle i {
  margin: 0;
  font-size: 18px;
}

/* ============ BUTTON ANIMATIONS ============ */
@keyframes button-line-out {
  0% {
    transform: scaleX(1);
    transform-origin: 100% 50%;
  }
  100% {
    transform: scaleX(0);
    transform-origin: 100% 50%;
  }
}

@keyframes button-line-in {
  0% {
    transform: scaleX(0);
    transform-origin: 0 50%;
  }
  100% {
    transform: scaleX(1);
    transform-origin: 0 50%;
  }
}

@keyframes button-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ============ BUTTON STYLES ============ */
.button-font-2 {
  font-size: 0.938em;
  letter-spacing: -0.2px;
  text-transform: none;
  font-weight: 400;
}

.button-radius {
  border-radius: 8px;
}

.button-rounded {
  border-radius: 50px;
}

.button-hover-float:hover,
.button-hover-float:focus {
  transform: translateY(-4px);
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.button-shadow {
  box-shadow: var(--theme-shadow-md);
}

.button-shadow:hover,
.button-shadow:focus {
  box-shadow: var(--theme-shadow-lg);
}

/* ============ DISABLED STATE ============ */
.button:disabled,
.button-disabled {
  background: var(--color-input-disabled-bg);
  border-color: var(--color-input-disabled-border);
  color: var(--color-input-disabled-text);
  cursor: not-allowed;
  opacity: 0.6;
  transform: none !important;
  box-shadow: none !important;
}

/* ============ LOADING STATE ============ */
.button-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}

.button-loading::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  border: 2px solid var(--button-loading-border);
  border-top-color: var(--button-loading-spinner);
  border-radius: 50%;
  animation: button-spin 0.8s linear infinite;
}

/* ============ BUTTON LAYOUT ============ */
.button-full {
  display: block;
  width: 100%;
  text-align: center;
}

/* Button Groups */
.button-group {
  display: inline-flex;
  gap: 0;
  border-radius: 6px;
  overflow: hidden;
}

.button-group .button {
  border-radius: 0;
  border-left-width: 0;
}

.button-group .button:first-child {
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
  border-left-width: 1px;
}

.button-group .button:last-child {
  border-top-right-radius: 6px;
  border-bottom-right-radius: 6px;
}

/* Icon Only Buttons */
.button-icon {
  padding: 12px;
  min-width: 48px;
  justify-content: center;
}

.button-icon i {
  margin: 0;
}

.button-icon.button-sm {
  padding: 10px;
  min-width: 40px;
}

.button-icon.button-lg {
  padding: 14px;
  min-width: 56px;
}

/* ============ DARK THEME OVERRIDES ============ */
[data-theme="dark"],
.dark-theme {
  .button-white {
    background: var(--color-gray-800);
    border-color: var(--theme-border-primary);
    color: var(--theme-text-primary);
  }
  
  .button-white:hover,
  .button-white:focus {
    background: var(--color-gray-700);
    border-color: var(--theme-border-secondary);
  }
  
  .button-circle-white {
    background: var(--color-gray-800);
    border-color: var(--theme-border-primary);
    color: var(--theme-text-primary);
  }
  
  .button-circle-white:hover,
  .button-circle-white:focus {
    background: var(--color-gray-700);
    border-color: var(--theme-border-secondary);
  }
}

/* ============ RESPONSIVE DESIGN ============ */
@media (max-width: 768px) {
  .button {
    padding: 10px 20px;
    font-size: 0.813em;
  }
  
  .button-lg {
    padding: 14px 28px;
  }
  
  .button-xl {
    padding: 16px 32px;
  }
  
  .button-circle {
    width: 44px;
    height: 44px;
  }
  
  .button-circle i {
    font-size: 16px;
  }
}

/* ============ ACCESSIBILITY ============ */
.button:focus-visible {
  outline: 2px solid var(--theme-primary);
  outline-offset: 2px;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .button,
  .button-circle,
  .button-loading::after {
    transition: none !important;
    animation: none !important;
  }
  
  .button:hover,
  .button:focus,
  .button-circle:hover,
  .button-circle:focus {
    transform: none;
  }
  
  .button-hover-float:hover,
  .button-hover-float:focus {
    transform: none;
  }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
  .button {
    border: 2px solid currentColor;
  }
  
  .button-outline-primary,
  .button-outline-secondary,
  .button-outline-dark {
    border-width: 3px;
  }
}

/* ============ PRINT STYLES ============ */
@media print {
  .button {
    border: 1px solid #000 !important;
    background: #fff !important;
    color: #000 !important;
    box-shadow: none !important;
  }
  
  .button-loading::after {
    display: none;
  }
}

/*# sourceMappingURL=static-a772f03d.c2002af7.min.css.map*/