/* =============================================================
   Future Plans — Components (Buttons, Cards, Modals, Forms, etc.)
   ============================================================= */

/* ── Buttons ── */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    font-size: var(--text-sm); font-weight: var(--weight-medium);
    transition: all var(--duration-fast) var(--ease-default);
    border: 1px solid transparent;
    cursor: pointer; white-space: nowrap;
    line-height: 1.5;
}
.btn:active { transform: scale(0.97); }
.btn i { font-size: var(--text-base); }

.btn--primary {
    background: var(--color-primary); color: var(--color-text-inverse);
    box-shadow: 0 1px 3px hsla(239,84%,67%,0.3);
}
.btn--primary:hover { background: var(--color-primary-hover); box-shadow: 0 4px 12px hsla(239,84%,67%,0.35); }
.btn--secondary { background: var(--color-surface); color: var(--color-text); border-color: var(--color-border); }
.btn--secondary:hover { background: var(--color-surface-hover); border-color: var(--color-text-muted); }
.btn--ghost { color: var(--color-text-secondary); }
.btn--ghost:hover { background: var(--color-surface-hover); color: var(--color-text); }
.btn--danger { background: var(--color-danger); color: var(--color-text-inverse); }
.btn--danger:hover { background: hsl(0,84%,52%); }
.btn--success { background: var(--color-success); color: var(--color-text-inverse); }
.btn--success:hover { background: hsl(160,84%,32%); }
.btn--sm { padding: var(--space-xs) var(--space-sm); font-size: var(--text-xs); }
.btn--lg { padding: var(--space-md) var(--space-lg); font-size: var(--text-md); }
.btn--icon { padding: var(--space-sm); width: 36px; height: 36px; }
.btn--block { width: 100%; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

/* ── Cards ── */
.card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    transition: all var(--duration-fast) var(--ease-default);
}
.card:hover { box-shadow: var(--shadow-md); }
.card--clickable { cursor: pointer; }
.card--clickable:hover { border-color: var(--color-primary); }
.card__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-md); }
.card__title { font-size: var(--text-md); font-weight: var(--weight-semibold); }
.card__body { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-relaxed); }
.card__footer { display: flex; align-items: center; gap: var(--space-sm); margin-top: var(--space-md); padding-top: var(--space-md); border-top: 1px solid var(--color-border-light); }

/* ── Stat Cards ── */
.stat-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    display: flex; align-items: flex-start; gap: var(--space-md);
    transition: all var(--duration-base) var(--ease-default);
}
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.stat-card__icon {
    width: 48px; height: 48px;
    border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--text-xl); flex-shrink: 0;
}
.stat-card__icon--primary { background: var(--color-primary-muted); color: var(--color-primary); }
.stat-card__icon--success { background: var(--color-success-light); color: var(--color-success); }
.stat-card__icon--warning { background: var(--color-warning-light); color: var(--color-warning); }
.stat-card__icon--danger  { background: var(--color-danger-light);  color: var(--color-danger); }
.stat-card__value { font-size: var(--text-2xl); font-weight: var(--weight-bold); }
.stat-card__label { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-2xs); }

/* ── Forms ── */
.form-group { margin-bottom: var(--space-md); }
.form-label {
    display: block; font-size: var(--text-sm); font-weight: var(--weight-medium);
    color: var(--color-text); margin-bottom: var(--space-xs);
}
.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    background: var(--color-surface);
    color: var(--color-text);
    transition: all var(--duration-fast) var(--ease-default);
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none; border-color: var(--color-primary);
    box-shadow: var(--shadow-focus);
}
.form-input::placeholder { color: var(--color-text-muted); }
.form-textarea { min-height: 100px; resize: vertical; }
.form-error { font-size: var(--text-xs); color: var(--color-danger); margin-top: var(--space-xs); }
.form-input--error { border-color: var(--color-danger); }
.form-hint { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-xs); }

/* ── Modal ── */
.modal-overlay {
    position: fixed; inset: 0;
    background: var(--color-overlay);
    z-index: var(--z-modal);
    display: flex; align-items: center; justify-content: center;
    padding: var(--space-md);
    opacity: 0; visibility: hidden;
    transition: all var(--duration-base) var(--ease-default);
}
.modal-overlay.is-open { opacity: 1; visibility: visible; }
.modal {
    background: var(--color-surface);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    width: 100%; max-width: 560px; max-height: 90vh;
    display: flex; flex-direction: column;
    transform: scale(0.95) translateY(10px);
    transition: transform var(--duration-base) var(--ease-bounce);
}
.modal-overlay.is-open .modal { transform: scale(1) translateY(0); }
.modal__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-lg); border-bottom: 1px solid var(--color-border-light);
}
.modal__title { font-size: var(--text-lg); font-weight: var(--weight-semibold); }
.modal__close {
    width: 32px; height: 32px; border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    color: var(--color-text-muted);
    transition: all var(--duration-fast) var(--ease-default);
}
.modal__close:hover { background: var(--color-surface-hover); color: var(--color-text); }
.modal__body { padding: var(--space-lg); overflow-y: auto; flex: 1; }
.modal__footer {
    display: flex; align-items: center; justify-content: flex-end; gap: var(--space-sm);
    padding: var(--space-md) var(--space-lg);
    border-top: 1px solid var(--color-border-light);
}

/* ── Badges ── */
.badge {
    display: inline-flex; align-items: center; gap: var(--space-2xs);
    padding: 2px 10px; border-radius: var(--radius-full);
    font-size: var(--text-xs); font-weight: var(--weight-semibold);
    line-height: 1.5;
}
.badge--waiting  { background: var(--color-warning-light); color: hsl(38,92%,35%); }
.badge--done     { background: var(--color-success-light); color: hsl(160,84%,25%); }
.badge--cancelled{ background: hsl(215,20%,93%); color: hsl(215,16%,40%); }
.badge--low      { background: hsl(215,20%,93%); color: var(--color-text-secondary); }
.badge--medium   { background: var(--color-primary-light); color: var(--color-primary); }
.badge--high     { background: var(--color-warning-light); color: hsl(38,92%,35%); }
.badge--critical { background: var(--color-danger-light); color: var(--color-danger); }

/* ── Toast Notifications ── */
.toast-container {
    position: fixed; top: var(--space-lg); right: var(--space-lg);
    z-index: var(--z-toast);
    display: flex; flex-direction: column; gap: var(--space-sm);
    pointer-events: none;
}
.toast {
    display: flex; align-items: center; gap: var(--space-sm);
    padding: var(--space-md) var(--space-lg);
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    border-left: 4px solid var(--color-primary);
    font-size: var(--text-sm);
    pointer-events: auto;
    animation: toastIn var(--duration-base) var(--ease-bounce);
    max-width: 380px;
}
.toast--success { border-left-color: var(--color-success); }
.toast--error   { border-left-color: var(--color-danger); }
.toast--warning { border-left-color: var(--color-warning); }
.toast__close {
    margin-left: auto; color: var(--color-text-muted);
    cursor: pointer; padding: var(--space-xs);
}
.toast__close:hover { color: var(--color-text); }

@keyframes toastIn {
    from { opacity: 0; transform: translateX(100%); }
    to   { opacity: 1; transform: translateX(0); }
}
@keyframes toastOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(100%); }
}

/* ── Empty State ── */
.empty-state {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: var(--space-3xl) var(--space-xl); text-align: center;
}
.empty-state__icon {
    width: 80px; height: 80px; border-radius: var(--radius-full);
    background: var(--color-primary-muted);
    display: flex; align-items: center; justify-content: center;
    font-size: var(--text-3xl); color: var(--color-primary);
    margin-bottom: var(--space-lg);
}
.empty-state__title { font-size: var(--text-lg); font-weight: var(--weight-semibold); margin-bottom: var(--space-xs); }
.empty-state__text { font-size: var(--text-sm); color: var(--color-text-muted); max-width: 360px; margin-bottom: var(--space-lg); }

/* ── Filter Bar ── */
.filter-bar {
    display: flex; align-items: center; gap: var(--space-sm);
    padding: var(--space-md); background: var(--color-surface);
    border: 1px solid var(--color-border); border-radius: var(--radius-lg);
    margin-bottom: var(--space-lg); flex-wrap: wrap;
}
.filter-bar__search {
    flex: 1; min-width: 200px; position: relative;
}
.filter-bar__search i {
    position: absolute; left: var(--space-sm); top: 50%; transform: translateY(-50%);
    color: var(--color-text-muted); font-size: var(--text-sm);
}
.filter-bar__search .form-input { padding-left: var(--space-xl); }

/* ── View Toggle ── */
.view-toggle {
    display: inline-flex; border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden;
}
.view-toggle__btn {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm); color: var(--color-text-secondary);
    transition: all var(--duration-fast) var(--ease-default);
    border: none; background: var(--color-surface); cursor: pointer;
}
.view-toggle__btn:not(:last-child) { border-right: 1px solid var(--color-border); }
.view-toggle__btn:hover { background: var(--color-surface-hover); }
.view-toggle__btn--active { background: var(--color-primary); color: var(--color-text-inverse); }

/* ── Dropdown ── */
.dropdown { position: relative; }
.dropdown__menu {
    position: absolute; top: calc(100% + 4px); right: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-border); border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg); padding: var(--space-xs);
    min-width: 180px; z-index: var(--z-dropdown);
    opacity: 0; visibility: hidden;
    transform: translateY(-4px);
    transition: all var(--duration-fast) var(--ease-default);
}
.dropdown__menu.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
.dropdown__item {
    display: flex; align-items: center; gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    font-size: var(--text-sm); color: var(--color-text-secondary);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-default);
}
.dropdown__item:hover { background: var(--color-surface-hover); color: var(--color-text); }

/* ── Color Swatch ── */
.color-swatch {
    width: 20px; height: 20px; border-radius: var(--radius-full);
    border: 2px solid var(--color-border); cursor: pointer;
    transition: transform var(--duration-fast) var(--ease-default);
}
.color-swatch:hover { transform: scale(1.15); }
.color-swatch--active { border-color: var(--color-text); box-shadow: 0 0 0 2px var(--color-surface), 0 0 0 4px var(--color-text); }

/* ── Loading Spinner ── */
.spinner {
    width: 20px; height: 20px;
    border: 2px solid var(--color-border);
    border-top-color: var(--color-primary);
    border-radius: var(--radius-full);
    animation: spin 0.6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.loading-overlay {
    position: absolute; inset: 0;
    background: hsla(0,0%,100%,0.7);
    display: flex; align-items: center; justify-content: center;
    border-radius: inherit; z-index: 10;
}
