/**
 * Carro Certo — Dynamic Table Widget
 * All colors are driven by CSS Variables set by Elementor controls.
 * Structural styles live here; branding comes from the editor.
 */

/* ──────────────────────────────────────────────
   CSS Variables (Defaults — overridden by Elementor selectors)
   ────────────────────────────────────────────── */
.elementor-widget-carrocerto_dynamic_table {
	--cc-table-header-color: #444444;
	--cc-table-header-color-hover: #222222;
	--cc-table-header-bg: #f8f9fb;
	--cc-table-header-bg-hover: #eef0f4;
	--cc-table-header-icon-hover: #444444;
	--cc-table-header-border-color: #edeff2;
	--cc-table-header-border-width: 2px;

	--cc-table-body-color: #1e293b;
	--cc-table-body-font-size: 14px;

	--cc-table-stripe-odd-bg: #fafafa;
	--cc-table-stripe-even-bg: #ffffff;

	--cc-table-group-border-color: #edeff2;
	--cc-table-group-border-width: 2px;

	--cc-table-sub-border-color: #f0f2f5;
	--cc-table-sub-border-width: 1px;

	--cc-table-wrapper-border-color: #f1f5f9;
	--cc-table-border-radius: 0px;

	--cc-table-search-bg: #ffffff;
	--cc-table-search-border-color: #e0e0e0;

	--cc-table-pagination-color: #777777;
	--cc-table-pagination-btn-bg: #ffffff;
	--cc-table-pagination-btn-hover: #f16421;

	--cc-table-sort-active-color: #f16421;
}

/* ──────────────────────────────────────────────
   Container
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table-container {
	margin: 20px 0;
}

/* ──────────────────────────────────────────────
   Search Input
   ────────────────────────────────────────────── */
.cc-table-search {
	margin-bottom: 20px;
}

.cc-search-input {
	width: 100%;
	padding: 12px 18px;
	border: 1px solid var(--cc-table-search-border-color);
	border-radius: 8px;
	font-size: 14px;
	outline: none;
	transition: border-color 0.3s, box-shadow 0.3s;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
	background-color: var(--cc-table-search-bg);
}

.cc-search-input:focus {
	border-color: var(--cc-table-sort-active-color);
	box-shadow: 0 0 0 3px rgba(241, 100, 33, 0.1);
}

/* ──────────────────────────────────────────────
   Table Wrapper
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table-wrapper {
	width: 100%;
	overflow-x: auto;
	border: 1px solid var(--cc-table-wrapper-border-color);
	border-radius: var(--cc-table-border-radius);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
}

/* ──────────────────────────────────────────────
   Table
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--cc-table-stripe-even-bg);
	table-layout: auto;
}

.carrocerto-dynamic-table th,
.carrocerto-dynamic-table td {
	padding: 14px 18px;
	line-height: 1.5;
	vertical-align: middle;
}

/* ──────────────────────────────────────────────
   Header
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table thead th {
	color: var(--cc-table-header-color);
	background-color: var(--cc-table-header-bg);
	font-size: var(--cc-table-body-font-size);
	font-weight: 700;
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 0.8px;
	border-bottom: var(--cc-table-header-border-width) solid var(--cc-table-header-border-color);
}

.carrocerto-dynamic-table thead th:hover {
	color: var(--cc-table-header-color-hover);
	background-color: var(--cc-table-header-bg-hover);
}

/* ──────────────────────────────────────────────
   Body Cells
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table tbody td {
	color: var(--cc-table-body-color);
	font-size: var(--cc-table-body-font-size);
}

/* ──────────────────────────────────────────────
   Zebra Striping
   ────────────────────────────────────────────── */
.cc-zebra-odd td,
.cc-zebra-odd {
	background-color: var(--cc-table-stripe-odd-bg);
}

.cc-zebra-even td,
.cc-zebra-even {
	background-color: var(--cc-table-stripe-even-bg);
}

/* ──────────────────────────────────────────────
   Row Groups
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table tr.cc-row-group-start {
	border-top: var(--cc-table-group-border-width) solid var(--cc-table-group-border-color);
}

.carrocerto-dynamic-table tr.cc-row-group-start:first-child {
	border-top: none;
}

/* ──────────────────────────────────────────────
   Sub-rows (Nested / Stacked)
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table tr.cc-sub-row td {
	border-top: var(--cc-table-sub-border-width) solid var(--cc-table-sub-border-color);
}

/* ──────────────────────────────────────────────
   Sub-field Labels
   ────────────────────────────────────────────── */
.cc-field-label {
	display: block;
	font-size: 10px;
	text-transform: uppercase;
	color: #888;
	letter-spacing: 0.5px;
	line-height: 1;
	margin-bottom: 4px;
}

/* ──────────────────────────────────────────────
   Column Alignment Classes
   ────────────────────────────────────────────── */
.cc-col-left {
	text-align: left;
}

.cc-col-center {
	text-align: center;
}

.cc-col-right {
	text-align: right;
}

/* Células com rowspan precisam de alinhamento vertical central */
.cc-td-valign-mid {
	vertical-align: middle;
}


/* ──────────────────────────────────────────────
   Sortable Headers
   ────────────────────────────────────────────── */
.carrocerto-dynamic-table thead th.cc-sortable {
	cursor: pointer;
	position: relative;
	padding-right: 30px;
	transition: background-color 0.2s, color 0.2s;
	user-select: none;
}

.cc-sort-icon {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 12px;
	height: 12px;
	opacity: 0.3;
}

.cc-sort-icon::before,
.cc-sort-icon::after {
	content: '';
	position: absolute;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	left: 2px;
}

.cc-sort-icon::before {
	border-bottom: 5px solid currentColor;
	top: 0;
}

.cc-sort-icon::after {
	border-top: 5px solid currentColor;
	bottom: 0;
}

/* Active sort: ascending */
.cc-sorted-asc .cc-sort-icon {
	opacity: 1;
	color: var(--cc-table-sort-active-color);
}

.cc-sorted-asc .cc-sort-icon::before {
	border-bottom-color: var(--cc-table-sort-active-color);
}

.cc-sorted-asc .cc-sort-icon::after {
	display: none;
}

/* Active sort: descending */
.cc-sorted-desc .cc-sort-icon {
	opacity: 1;
	color: var(--cc-table-sort-active-color);
}

.cc-sorted-desc .cc-sort-icon::before {
	display: none;
}

.cc-sorted-desc .cc-sort-icon::after {
	border-top-color: var(--cc-table-sort-active-color);
	top: 4px;
}

/* Hover sort icon */
.carrocerto-dynamic-table thead th.cc-sortable:hover .cc-sort-icon::before {
	border-bottom-color: var(--cc-table-header-icon-hover);
}

.carrocerto-dynamic-table thead th.cc-sortable:hover .cc-sort-icon::after {
	border-top-color: var(--cc-table-header-icon-hover);
}

/* ──────────────────────────────────────────────
   Pagination
   ────────────────────────────────────────────── */
.cc-table-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 20px;
	gap: 12px;
}

.cc-table-pagination button {
	padding: 8px 16px;
	border: 1px solid #e0e0e0;
	background-color: var(--cc-table-pagination-btn-bg);
	border-radius: 6px;
	cursor: pointer;
	transition: background-color 0.2s, border-color 0.2s, color 0.2s;
	font-weight: 600;
	font-size: 13px;
	color: #555;
}

.cc-table-pagination button:hover:not(:disabled) {
	background-color: var(--cc-table-pagination-btn-hover);
	border-color: var(--cc-table-pagination-btn-hover);
	color: #fff;
	box-shadow: 0 4px 8px rgba(241, 100, 33, 0.2);
}

.cc-table-pagination button:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.cc-page-info {
	font-size: 13px;
	font-weight: 600;
	color: var(--cc-table-pagination-color);
}