/* ============================================================
   COLE — Components (macOS inspired)
   ============================================================ */

/* === Tabs === */
.cole-tabs { display: flex; border-bottom: 1px solid var(--cole-border); overflow-x: auto; gap: 0; }
.cole-tabs::-webkit-scrollbar { display: none; }
.cole-tab {
    padding: var(--cole-space-sm) var(--cole-space-md);
    font-size: var(--cole-font-size-sm); color: var(--cole-text-secondary);
    font-weight: var(--cole-font-weight-medium); cursor: pointer;
    border-bottom: 2px solid transparent; transition: all var(--cole-transition-fast);
    white-space: nowrap; background: none; border-top: none; border-left: none; border-right: none;
}
.cole-tab:hover { color: var(--cole-text-primary); }
.cole-tab.active { color: var(--cole-primary); border-bottom-color: var(--cole-primary); }

/* === Tables === */
.cole-table-wrap { overflow-x: auto; border: 1px solid var(--cole-border); border-radius: var(--cole-radius-md); }
.cole-table { width: 100%; border-collapse: collapse; font-size: var(--cole-font-size-sm); }
.cole-table th {
    text-align: left; padding: var(--cole-space-sm) var(--cole-space-md);
    font-weight: var(--cole-font-weight-semibold); font-size: var(--cole-font-size-xs);
    text-transform: uppercase; letter-spacing: 0.04em; color: var(--cole-text-muted);
    background: var(--cole-bg-surface-hover); border-bottom: 1px solid var(--cole-border);
}
.cole-table td { padding: var(--cole-space-sm) var(--cole-space-md); border-bottom: 1px solid var(--cole-border); }
.cole-table tr:hover td { background: var(--cole-bg-surface-hover); }
.cole-table tr:last-child td { border-bottom: none; }

/* === Progress === */
.cole-progress { width: 100%; height: 6px; background: var(--cole-border-strong); border-radius: var(--cole-radius-full); overflow: hidden; }
.cole-progress__bar { height: 100%; background: var(--cole-primary); transition: width var(--cole-transition-slow); border-radius: var(--cole-radius-full); }
.cole-progress__bar--success { background: var(--cole-success); }
.cole-progress__bar--warning { background: var(--cole-warning); }
.cole-progress__bar--danger { background: var(--cole-error); }

/* === Dropdown === */
.cole-dropdown { position: relative; display: inline-block; }
.cole-dropdown__menu {
    display: none; position: absolute; top: calc(100% + 4px); right: 0;
    min-width: 180px; background: var(--cole-bg-elevated); border: 1px solid var(--cole-border);
    border-radius: var(--cole-radius-md); box-shadow: var(--cole-shadow-lg);
    z-index: var(--cole-z-dropdown); padding: var(--cole-space-xs);
    animation: cole-scale-in 0.15s ease;
}
.cole-dropdown__menu.open { display: block; }
.cole-dropdown__item {
    display: flex; align-items: center; gap: var(--cole-space-sm);
    padding: 8px 12px; border-radius: var(--cole-radius-sm);
    font-size: var(--cole-font-size-sm); color: var(--cole-text-secondary);
    transition: all var(--cole-transition-fast); cursor: pointer;
    width: 100%; text-align: left; background: none; border: none; text-decoration: none;
}
.cole-dropdown__item:hover { background: var(--cole-bg-surface-hover); color: var(--cole-text-primary); }

/* === Tooltip === */
.cole-tooltip { position: relative; }
.cole-tooltip::after {
    content: attr(data-tooltip); position: absolute; bottom: calc(100% + 6px);
    left: 50%; transform: translateX(-50%); padding: 4px 10px;
    background: var(--cole-text-primary); color: var(--cole-bg-surface);
    font-size: var(--cole-font-size-xs); border-radius: var(--cole-radius-sm);
    white-space: nowrap; opacity: 0; pointer-events: none;
    transition: opacity var(--cole-transition-fast);
}
.cole-tooltip:hover::after { opacity: 1; }

/* === Skeleton === */
.cole-skeleton { background: linear-gradient(90deg, var(--cole-border) 25%, var(--cole-bg-surface-hover) 50%, var(--cole-border) 75%); background-size: 200% 100%; animation: cole-shimmer 1.5s infinite; border-radius: var(--cole-radius-sm); }
@keyframes cole-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.cole-skeleton-text { height: 14px; margin-bottom: 8px; }
.cole-skeleton-text:last-child { width: 60%; }
.cole-skeleton-circle { width: 40px; height: 40px; border-radius: 50%; }
.cole-skeleton-rect { height: 120px; }

/* === Breadcrumbs === */
.cole-breadcrumbs { display: flex; align-items: center; gap: var(--cole-space-xs); font-size: var(--cole-font-size-sm); color: var(--cole-text-muted); flex-wrap: wrap; }
.cole-breadcrumbs a { color: var(--cole-text-secondary); text-decoration: none; }
.cole-breadcrumbs a:hover { color: var(--cole-primary); }
.cole-breadcrumbs__sep::before { content: '/'; margin: 0 2px; }
.cole-breadcrumbs__current { color: var(--cole-text-primary); font-weight: var(--cole-font-weight-medium); }

/* === Pagination === */
.cole-pagination { display: flex; justify-content: center; gap: var(--cole-space-xs); padding: var(--cole-space-md) 0; }
.cole-pagination__btn {
    min-width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
    border-radius: var(--cole-radius-sm); font-size: var(--cole-font-size-sm);
    color: var(--cole-text-secondary); transition: all var(--cole-transition-fast);
    background: none; border: 1px solid transparent; cursor: pointer; text-decoration: none;
}
.cole-pagination__btn:hover { background: var(--cole-bg-surface-hover); color: var(--cole-primary); border-color: var(--cole-border); }
.cole-pagination__btn.active { background: var(--cole-primary); color: #fff; border-color: var(--cole-primary); }

/* === Toggle === */
.cole-toggle { position: relative; width: 44px; height: 24px; cursor: pointer; display: inline-block; }
.cole-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.cole-toggle__slider {
    position: absolute; inset: 0; background: var(--cole-border-strong);
    border-radius: var(--cole-radius-full); transition: background var(--cole-transition-fast);
}
.cole-toggle__slider::before {
    content: ''; position: absolute; top: 2px; left: 2px;
    width: 20px; height: 20px; background: #fff;
    border-radius: 50%; box-shadow: var(--cole-shadow-sm);
    transition: transform var(--cole-transition-fast);
}
.cole-toggle input:checked + .cole-toggle__slider { background: var(--cole-primary); }
.cole-toggle input:checked + .cole-toggle__slider::before { transform: translateX(20px); }

/* === Search === */
.cole-search { position: relative; }
.cole-search__icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--cole-text-muted); pointer-events: none; }
.cole-search .cole-input { padding-left: 38px; }

/* === Stat card === */
.cole-stat { display: flex; flex-direction: column; gap: var(--cole-space-xs); }
.cole-stat__label { font-size: var(--cole-font-size-xs); font-weight: var(--cole-font-weight-medium); color: var(--cole-text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.cole-stat__value { font-size: var(--cole-font-size-3xl); font-weight: var(--cole-font-weight-bold); color: var(--cole-primary); line-height: 1; }
.cole-stat__change { font-size: var(--cole-font-size-xs); font-weight: var(--cole-font-weight-medium); }
.cole-stat__change--up { color: var(--cole-success); }
.cole-stat__change--down { color: var(--cole-error); }

/* === Landing components (used in base pages) === */
.cole-landing { min-height: 100vh; overflow-y: auto; }
.cole-hero { display: flex; flex-direction: column; align-items: center; min-height: 80vh; text-align: center; padding: var(--cole-space-3xl) var(--cole-space-lg); background: var(--cole-bg-body); position: relative; }
.cole-hero__badge { display: inline-flex; gap: var(--cole-space-xs); padding: 6px 16px; background: rgba(79,70,229,0.08); color: var(--cole-primary); border-radius: var(--cole-radius-full); font-size: var(--cole-font-size-sm); font-weight: var(--cole-font-weight-medium); margin-bottom: var(--cole-space-lg); }
.cole-hero h1 { font-size: clamp(2rem, 5vw, 3.5rem); max-width: 800px; margin-bottom: var(--cole-space-md); line-height: 1.15; letter-spacing: -0.02em; }
.cole-hero h1 span { background: linear-gradient(135deg, var(--cole-primary), var(--cole-secondary)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.cole-hero__subtitle { font-size: var(--cole-font-size-lg); color: var(--cole-text-secondary); max-width: 600px; margin-bottom: var(--cole-space-xl); }
.cole-hero__actions { display: flex; gap: var(--cole-space-md); flex-wrap: wrap; justify-content: center; }

/* === Features grid === */
.cole-features { padding: var(--cole-space-3xl) var(--cole-space-lg); background: var(--cole-bg-surface); }
.cole-features__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--cole-space-lg); max-width: 1200px; margin: 0 auto; }
.cole-feature-card { padding: var(--cole-space-xl); border: 1px solid var(--cole-border); border-radius: var(--cole-radius-lg); transition: all var(--cole-transition-normal); background: var(--cole-bg-surface); }
.cole-feature-card:hover { border-color: var(--cole-primary-light); transform: translateY(-2px); box-shadow: var(--cole-shadow-md); }
.cole-feature-card__icon { width: 48px; height: 48px; border-radius: var(--cole-radius-md); display: flex; align-items: center; justify-content: center; font-size: 24px; margin-bottom: var(--cole-space-md); }
.cole-feature-card__title { font-size: var(--cole-font-size-lg); font-weight: var(--cole-font-weight-semibold); margin-bottom: var(--cole-space-sm); }
.cole-feature-card__text { font-size: var(--cole-font-size-sm); color: var(--cole-text-secondary); line-height: 1.6; }

/* === Auth components === */
.cole-auth__card--wide { max-width: 560px; }
