/* ═══════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;font-family:var(--font-primary);font-size:var(--text-sm);font-weight:var(--weight-semibold);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none;line-height:1}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-primary{background:var(--color-primary);color:var(--color-dark);font-weight:var(--weight-bold)}.btn-primary:hover{background:#E69A00;color:var(--color-dark)}
.btn-secondary{background:transparent;color:var(--color-dark);border:2px solid var(--color-primary)}.btn-secondary:hover{background:var(--color-primary);color:var(--color-dark)}
.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-danger:hover{background:#a52222}
.btn-ghost{background:transparent;color:var(--text-secondary);padding:6px 12px;font-weight:var(--weight-medium)}.btn-ghost:hover{color:var(--color-primary);background:rgba(var(--color-primary-rgb), 0.05)}
.btn-sm{padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-sm)}
.btn-lg{padding:14px 28px;font-size:var(--text-base)}
.btn-block{width:100%;justify-content:center}

/* ═══════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════ */
.card{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);transition:transform var(--transition-base),box-shadow var(--transition-base)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card__image{border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--space-lg)}
.card__image img{width:100%;height:200px;object-fit:cover}
.card__title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text-primary);margin-bottom:var(--space-sm)}
.card__text{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}
.card__link{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-primary);display:inline-flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-base)}
.card__link:hover{color:var(--color-primary)}

.stats-card{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-sm)}
.stats-card__header{display:flex;align-items:center;justify-content:space-between}
.stats-card__icon{font-size:var(--text-2xl)}
.stats-card__value{font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--text-primary)}
.stats-card__label{font-size:var(--text-sm);color:var(--text-secondary)}

/* ═══════════════════════════════════════════
   FORM CONTROLS
   ═══════════════════════════════════════════ */
.form-group{margin-bottom:var(--space-lg)}
.form-label{display:block;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-primary);margin-bottom:var(--space-sm)}
.form-control{width:100%;padding:10px 14px;font-family:var(--font-primary);font-size:var(--text-base);color:var(--text-primary);background:var(--color-white);border:1px solid var(--color-light);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}
.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),0.15)}
.form-control.error{border-color:var(--color-danger)}
.form-error{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-xs)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23757575' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
textarea.form-control{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}

/* ═══════════════════════════════════════════
   DATA TABLE
   ═══════════════════════════════════════════ */
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.data-table{width:100%;border-collapse:collapse;background:var(--color-white)}
.data-table thead{background:var(--color-light);border-bottom:1px solid rgba(0,0,0,0.05)}
.data-table th{padding:var(--space-md) var(--space-base);font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--color-dark);text-transform:uppercase;letter-spacing:0.05em;text-align:left}
.data-table td{padding:var(--space-md) var(--space-base);font-size:var(--text-sm);color:var(--text-primary);border-bottom:1px solid var(--color-light)}
.data-table tbody tr:hover{background:rgba(var(--color-primary-rgb), 0.03)}
.data-table .actions{display:flex;gap:var(--space-sm)}

/* ═══════════════════════════════════════════
   BADGES
   ═══════════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:var(--text-xs);font-weight:var(--weight-semibold);border-radius:var(--radius-full);line-height:1.4}
.badge--active,.badge--published,.badge--paid{background:var(--color-success-light);color:var(--color-success)}
.badge--on-hold,.badge--sent{background:var(--color-warning-light);color:var(--color-warning)}
.badge--completed,.badge--info{background:var(--color-info-light);color:var(--color-info)}
.badge--cancelled,.badge--draft,.badge--inactive{background:var(--color-light);color:var(--text-secondary)}
.badge--overdue,.badge--danger{background:var(--color-danger-light);color:var(--color-danger)}
.badge--prospect{background:var(--color-info-light);color:var(--color-info)}

/* ═══════════════════════════════════════════
   ALERTS
   ═══════════════════════════════════════════ */
.alert{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-base) var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-sm);border-left:4px solid;margin-bottom:var(--space-lg);animation:slideDown .3s ease}
.alert--success{background:var(--color-success-light);border-color:var(--color-success);color:var(--color-success)}
.alert--danger{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}
.alert--warning{background:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning)}
.alert--info{background:var(--color-info-light);border-color:var(--color-info);color:var(--color-info)}
.alert__close{background:none;border:none;font-size:var(--text-lg);cursor:pointer;opacity:.6;color:inherit}.alert__close:hover{opacity:1}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════════ */
.pagination{display:flex;align-items:center;gap:var(--space-xs);justify-content:center;margin-top:var(--space-xl)}
.pagination__item{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--weight-medium);border-radius:var(--radius-md);border:1px solid var(--color-light);color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}
.pagination__item:hover{border-color:var(--color-primary);color:var(--color-primary)}
.pagination__item.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-dark)}

/* ═══════════════════════════════════════════
   MODAL
   ═══════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:var(--surface-overlay);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all var(--transition-base)}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--space-xl);width:90%;max-width:500px;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-xl);transform:translateY(20px);transition:transform var(--transition-base)}
.modal-overlay.active .modal{transform:translateY(0)}
.modal__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}
.modal__title{font-size:var(--text-xl);font-weight:var(--weight-semibold)}
.modal__close{background:none;border:none;font-size:var(--text-xl);cursor:pointer;color:var(--text-muted)}

/* ═══════════════════════════════════════════
   TABS
   ═══════════════════════════════════════════ */
.tabs{display:flex;border-bottom:2px solid var(--color-light);margin-bottom:var(--space-xl)}
.tab{padding:var(--space-md) var(--space-lg);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all var(--transition-fast)}
.tab:hover{color:var(--text-primary)}
.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}
.tab-content{display:none}.tab-content.active{display:block}

/* ═══════════════════════════════════════════
   MISC
   ═══════════════════════════════════════════ */
.section{padding:var(--space-6xl) 0;background:var(--color-white)}
.section--gray{background:var(--color-light)}
.section--dark{background:var(--color-dark);color:var(--color-white)}
.section__title{font-size:var(--text-4xl);font-weight:var(--weight-bold);margin-bottom:var(--space-base);line-height:var(--leading-tight);color:var(--text-primary)}
.section--dark .section__title{color:var(--color-white)}
.section__subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:600px}
.section--dark .section__subtitle{color:rgba(255,255,255,0.7)}
.section__header{margin-bottom:var(--space-3xl)}
.divider{height:4px;width:60px;background:var(--color-primary);margin:var(--space-base) 0;border-radius:var(--radius-full)}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-base)}
.filter-bar{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-lg)}
.filter-bar .btn{font-size:var(--text-xs)}
.flash-container{position:fixed;top:90px;right:20px;z-index:3000;width:360px}

.empty-state{text-align:center;padding:var(--space-4xl);color:var(--text-muted)}
.empty-state__icon{font-size:3rem;margin-bottom:var(--space-base)}
.empty-state__text{font-size:var(--text-lg);margin-bottom:var(--space-lg)}

