/* LastWish Design System - Wireframe Color Scheme */

/* Core Palette (Wireframe-aligned) */
:root {
  --brand-primary-start: #667eea; /* Indigo 500 */
  --brand-primary-end: #764ba2;   /* Purple 600 */
  --brand-secondary: #f093fb;     /* Magenta accent */
  --brand-success-start: #48bb78; /* Green 500 */
  --brand-success-end: #38a169;   /* Green 600 */
  --brand-warning-start: #ed8936; /* Orange 500 */
  --brand-warning-end: #dd6b20;   /* Orange 600 */
  --brand-danger: #dc3545;        /* Red */
  --brand-info: #36b9cc;          /* Teal */

  --text-primary: #1a202c;        /* Slate 900 */
  --text-secondary: #64748b;      /* Slate 500 */
  --text-muted: #6c757d;

  --background-white: #ffffff;
  --background-light: #f8f9fa;
  --background-muted: #f8fafc;
  --border-light: #e9ecef;
}

/* Gradients */
.lw-gradient-primary {
  background: linear-gradient(135deg, var(--brand-primary-start) 0%, var(--brand-primary-end) 100%);
  color: #fff;
}
.lw-gradient-success {
  background: linear-gradient(135deg, var(--brand-success-start) 0%, var(--brand-success-end) 100%);
  color: #fff;
}
.lw-gradient-warning {
  background: linear-gradient(135deg, var(--brand-warning-start) 0%, var(--brand-warning-end) 100%);
  color: #fff;
}

/* Text Utilities */
.lw-text-primary { color: var(--text-primary) !important; }
.lw-text-secondary { color: var(--text-secondary) !important; }
.lw-text-muted { color: var(--text-muted) !important; }
.lw-text-inverse { color: #fff !important; }

/* Background Utilities */
.lw-bg-white { background: var(--background-white) !important; }
.lw-bg-light { background: var(--background-light) !important; }
.lw-bg-muted { background: var(--background-muted) !important; }

/* Border Utilities */
.lw-border-light { border-color: var(--border-light) !important; }

/* Buttons */
.lw-btn { display: inline-flex; align-items: center; gap: .5rem; padding: .625rem 1rem; border-radius: .5rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: all .2s ease; }
.lw-btn-primary { background: linear-gradient(135deg, var(--brand-primary-start), var(--brand-primary-end)); color: #fff; }
.lw-btn-primary:hover { filter: brightness(1.05); box-shadow: 0 6px 12px rgba(102,126,234,.25); transform: translateY(-1px); }
.lw-btn-success { background: linear-gradient(135deg, var(--brand-success-start), var(--brand-success-end)); color: #fff; }
.lw-btn-warning { background: linear-gradient(135deg, var(--brand-warning-start), var(--brand-warning-end)); color: #fff; }
.lw-btn-danger { background: var(--brand-danger); color: #fff; }
.lw-btn-secondary { background: var(--text-muted); color: #fff; }

/* Badges */
.lw-badge { display: inline-block; padding: .25rem .6rem; border-radius: 999px; font-size: .75rem; font-weight: 700; }
.lw-badge-primary { background: var(--brand-secondary); color: #fff; }
.lw-badge-success { background: var(--brand-success-end); color: #fff; }
.lw-badge-warning { background: var(--brand-warning-end); color: #fff; }
.lw-badge-info { background: var(--brand-info); color: #fff; }
.lw-badge-danger { background: var(--brand-danger); color: #fff; }

/* Cards */
.lw-card { background: var(--background-white); border-radius: 12px; box-shadow: 0 4px 10px rgba(0,0,0,.06); border: 1px solid var(--border-light); }
.lw-card-body { padding: 1rem; }
.lw-card-header { padding: .75rem 1rem; border-bottom: 1px solid var(--border-light); font-weight: 600; color: var(--text-primary); }
.lw-card-footer { padding: .75rem 1rem; border-top: 1px solid var(--border-light); }

/* Alerts */
.lw-alert { padding: .75rem 1rem; border-radius: 10px; border: 1px solid var(--border-light); display: flex; align-items: center; gap: .5rem; }
.lw-alert-success { background: #d4edda; color: #155724; border-color: #c3e6cb; }
.lw-alert-danger { background: #f8d7da; color: #721c24; border-color: #f5c6cb; }
.lw-alert-warning { background: #fff3cd; color: #856404; border-color: #ffeeba; }
.lw-alert-info { background: #d1ecf1; color: #0c5460; border-color: #bee5eb; }

/* Navigation helpers */
.lw-nav-link { color: var(--text-secondary); text-decoration: none; padding: .5rem .75rem; border-radius: .5rem; transition: .2s ease; }
.lw-nav-link:hover, .lw-nav-link.active { background: linear-gradient(135deg, var(--brand-primary-start), var(--brand-primary-end)); color: #fff; }

/* Common class mappings (to unify templates using Tailwind-like classes) */
.text-blue-600 { color: var(--brand-primary-end) !important; }
.bg-blue-600 { background-color: var(--brand-primary-end) !important; color: #fff; }
.text-gray-900 { color: var(--text-primary) !important; }
.text-gray-600 { color: var(--text-secondary) !important; }
.bg-gray-50 { background-color: var(--background-light) !important; }
.border-gray-200 { border-color: var(--border-light) !important; }

/* Feature icons and accents */
.feature-icon.primary { background: linear-gradient(135deg, var(--brand-primary-start), var(--brand-primary-end)); color: #fff; }
.feature-icon.success { background: linear-gradient(135deg, var(--brand-success-start), var(--brand-success-end)); color: #fff; }
.feature-icon.warning { background: linear-gradient(135deg, var(--brand-warning-start), var(--brand-warning-end)); color: #fff; }

/* Footer accents */
.footer-section h4::after { background: linear-gradient(90deg, var(--brand-primary-start), var(--brand-primary-end)); }
.footer-brand .brand-logo h3 { color: var(--brand-primary-start); }

/* Accessibility: high-contrast focus ring */
:focus-visible { outline: 3px solid var(--brand-primary-start); outline-offset: 2px; }