/* =======================================================
   ROOT VARIABLES
======================================================= */

:root {
    /* CORE COLORS */
    --bs-primary: var(--color-primary) !important;
    --bs-secondary: var(--color-secondary) !important;
    --bs-success: var(--color-success) !important;
    --bs-warning: var(--color-warning) !important;
    --bs-danger: var(--color-error) !important;
    --bs-info: var(--color-info) !important;
    --bs-light: var(--color-neutral-content) !important;
    --bs-dark: var(--color-neutral) !important;

    /* BODY */
    --bs-body-bg-100: var(--color-base-100) !important;
    --bs-body-bg-200: var(--color-base-200) !important;
    --bs-body-bg-300: var(--color-base-300) !important;
    --bs-body-bg: var(--color-base-100) !important;
    --bs-body-color: var(--color-base-content) !important;
    --bs-body-primary: var(--color-primary) !important;

    /* LINKS */
    --bs-link-color: var(--color-primary) !important;
    --bs-link-hover-color: var(--color-primary) !important;

    /* BORDERS */
    --bs-border-color: var(--color-base-300) !important;
    --bs-border-color-translucent: var(--color-base-300) !important;

    /* RADIUS */
    --bs-border-radius: 0.5rem !important;
    --bs-border-radius-sm: 0.375rem !important;
    --bs-border-radius-lg: 0.75rem !important;
    --bs-btn-border-radius: 0.375rem !important;
    --bs-form-control-border-radius: 0.375rem !important;
}

/* =======================================================
   UTILITIES
======================================================= */

.bg-primary {
    background-color: var(--color-primary) !important;
}

.border-primary {
    border-color: var(--color-primary) !important;
}

.text-primary { color: var(--color-primary) !important; }
.text-secondary { color: var(--color-secondary) !important; }
.text-success { color: var(--color-success) !important; }
.text-warning { color: var(--color-warning) !important; }
.text-danger { color: var(--color-error) !important; }
.text-info { color: var(--color-info) !important; }
.text-base-content { color: var(--color-base-content) !important; }
.text-base-200 { color: var(--color-base-200) !important; }

.gradient-text {
    background: linear-gradient(to bottom, var(--color-primary), var(--color-primary-content));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

a {
    text-decoration: none !important;
}
a.card-link {
    all: unset;
    display: block;
    cursor: pointer;
}

a.text-primary:hover { color: var(--color-primary) !important; }
a.text-secondary:hover { color: var(--color-secondary-content) !important; }
a.text-success:hover { color: var(--color-success-content) !important; }
a.text-warning:hover { color: var(--color-warning-content) !important; }
a.text-danger:hover { color: var(--color-error-content) !important; }
a.text-info:hover { color: var(--color-info-content) !important; }
a.text-base-content:hover { color: var(--color-base-content) !important; }

/* =======================================================
   BUTTONS (BOOTSTRAP OVERRIDES)
======================================================= */

a:focus,
a:active { 
    box-shadow: none !important; 
}
button:focus,
button:active {
    box-shadow: none !important;
}

.btn {
    padding: 0.75rem 1rem !important;
    transition: all 0.15s ease !important;
    text-transform: none !important;
    display: inline-flex !important;
    outline: none !important;
    white-space: normal !important;
    height: auto !important;
}

.btn:hover { 
    filter: brightness(0.95) !important; 
}

.btn:active { 
    filter: brightness(0.9) !important;
    outline: none !important;
}

.btn-primary {
    height: 50px !important;
    justify-content: center !important;
    background-image: linear-gradient(to right, var(--color-primary), var(--color-primary-content)) !important;
    border: none !important;
    color: var(--color-base-100) !important;
}

.btn-secondary {
    background-color: var(--color-secondary) !important;
    border-color: var(--color-secondary) !important;
    color: var(--color-base-100) !important;
}

.btn-success {
    background-color: var(--color-success) !important;
    border-color: var(--color-success) !important;
    color: var(--color-success-content) !important;
}

.btn-warning {
    background-color: var(--color-warning) !important;
    border-color: var(--color-warning) !important;
    color: var(--color-warning-content) !important;
}

.btn-danger {
    background-color: var(--color-error) !important;
    border-color: var(--color-error) !important;
    color: var(--color-error-content) !important;
}

.btn-info {
    background-color: var(--color-info) !important;
    border-color: var(--color-info) !important;
    color: var(--color-info-content) !important;
}

.btn-base-200 {
    background-color: var(--color-base-200) !important;
    border-color: var(--color-base-300) !important;
    color: var(--color-base-content) !important;
}

.btn-base-300 {
    background-color: var(--color-base-300) !important;
    border-color: var(--color-base-300) !important;
    color: var(--color-primary) !important;
}

/* OUTLINE BUTTONS */

.btn-outline-primary {
    color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    background-color: var(--color-primary) !important;
    color: var(--color-primary-content) !important;
    border-color: var(--color-primary) !important;
}

.btn-outline-secondary {
    color: var(--color-secondary) !important;
    border-color: var(--color-secondary) !important;
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus,
.btn-outline-secondary:active {
    background-color: var(--color-secondary) !important;
    color: var(--color-secondary-content) !important;
    border-color: var(--color-secondary) !important;
}

.btn-outline-success {
    color: var(--color-success) !important;
    border-color: var(--color-success) !important;
}

.btn-outline-success:hover,
.btn-outline-success:focus,
.btn-outline-success:active {
    background-color: var(--color-success) !important;
    color: var(--color-success-content) !important;
    border-color: var(--color-success) !important;
}

.btn-outline-warning {
    color: var(--color-warning) !important;
    border-color: var(--color-warning) !important;
}

.btn-outline-warning:hover,
.btn-outline-warning:focus,
.btn-outline-warning:active {
    background-color: var(--color-warning) !important;
    color: var(--color-warning-content) !important;
    border-color: var(--color-warning) !important;
}

.btn-outline-danger {
    color: var(--color-error) !important;
    border-color: var(--color-error) !important;
}

.btn-outline-danger:hover,
.btn-outline-danger:focus,
.btn-outline-danger:active {
    background-color: var(--color-error) !important;
    color: var(--color-error-content) !important;
    border-color: var(--color-error) !important;
}

.btn-outline-info {
    color: var(--color-info) !important;
    border-color: var(--color-info) !important;
}

.btn-outline-info:hover,
.btn-outline-info:focus,
.btn-outline-info:active {
    background-color: var(--color-info) !important;
    color: var(--color-info-content) !important;
    border-color: var(--color-info) !important;
}

/* =======================================================
   COMPONENTS
======================================================= */

.card {
    background-color: var(--color-base-200) !important;
    border-color: var(--color-base-300) !important;
    color: var(--color-base-content) !important;
}

/* ALERTS */

.alert-primary {
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: var(--color-primary-content) !important;
}

.alert-secondary {
    background-color: var(--color-secondary) !important;
    border-color: var(--color-secondary) !important;
    color: var(--color-secondary-content) !important;
}

/* BADGES */

.badge.bg-primary {
    background-color: var(--color-primary) !important;
    color: var(--color-primary-content) !important;
}

.badge.bg-secondary {
    background-color: var(--color-secondary) !important;
    color: var(--color-secondary-content) !important;
}

/* LIST GROUP */

.list-group-item.active {
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
    color: var(--color-primary-content) !important;
}

/* NAV TABS */

.nav-tabs .nav-link.active {
    background-color: var(--color-primary) !important;
    color: var(--color-primary-content) !important;
    border-color: var(--color-base-300) !important;
}

/* NAVBAR */

.navbar .nav-link {
    display: flex;
    align-items: center;
    gap: 0.1rem;
    padding: 0.45rem 0.9rem;
    border-radius: 0.6rem;
    text-decoration: none;
    color: var(--color-base-content) !important;
    transition: all 0.2s ease;
    opacity: 0.6;
}

.nav-link:hover {
    background-color: transparent !important;
    color: var(--color-primary) !important;
}

.nav-link.active {
    color: var(--color-primary) !important;
    opacity: 1;
}

/* DROPDOWN */

.dropdown-menu {
    background-color: var(--color-base-100) !important;
    border-color: var(--color-base-300) !important;
}

.dropdown-item:hover {
    background-color: var(--color-base-200) !important;
}


.modal-content {
    background-color: var(--color-base-100) !important;
    border-color: var(--color-base-300) !important;
}

/* =======================================================
   FORMS
======================================================= */

input,
textarea,
select,
.form-control,
.form-select {
    background-color: oklch(1 0 89.876) !important;
    color: oklch(0 0 0) !important;
    border: 1px solid var(--color-base-300) !important;
    border-radius: 0.5rem !important;
    padding: 0.65rem 0.85rem !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    text-transform: none !important;
    box-shadow: none !important;
}

input:focus,
textarea:focus,
select:focus{
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 1px var(--color-primary) !important;
    outline: none !important;
}

input::placeholder,
textarea::placeholder {
    color: oklch(0.607 0 89.876) !important;
    opacity: 0.8 !important;
    font-size: 1rem !important;
}

.form-check-input:checked {
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
}

.form-select.is-placeholder {
    background-color: oklch(1 0 89.876) !important;
    color: oklch(0.607 0 89.876) !important;
    font-size: 0.9rem !important;
}

/* =======================================================
   TAB CONTROLS (период: неделя / месяц / год)
======================================================= */

.tab-controls {
    display: flex;
    border: 1px solid var(--color-primary);
    border-radius: 0.5rem;
    overflow: hidden;
}

.tab-controls a,
.tab-controls button {
    flex: 1;
    text-align: center;
    padding: 0.5rem 0.5rem;
    cursor: pointer;
    background: transparent;
    color: var(--color-primary);
    font-size: 0.8125rem;
    border: none;
    outline: none;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
    white-space: nowrap;
}

.tab-controls a.collapsed,
.tab-controls button.collapsed {
    opacity: 0.55;
}

.tab-controls a:not(.collapsed),
.tab-controls button:not(.collapsed) {
    background: linear-gradient(to right, var(--color-primary), var(--color-primary-content));
    color: var(--color-base-100);
    font-weight: 500;
    opacity: 1;
}

/* =======================================================
   OFFCANVAS (тёмная тема)
======================================================= */

.offcanvas {
    background-color: var(--color-base-200) !important;
    color: var(--color-base-content) !important;
}

.offcanvas-header {
    border-bottom: 1px solid var(--color-base-300) !important;
    padding: 0.85rem 1rem !important;
}

.offcanvas-title {
    font-size: 0.9375rem !important;
    font-weight: 500 !important;
}

.offcanvas-body {
    padding: 0 !important;
    overflow-y: auto;
}

.offcanvas-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.85rem 1rem;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--color-base-300);
    color: var(--color-base-content);
    font-size: 0.875rem;
    text-align: left;
    cursor: pointer;
    transition: background 0.15s ease;
}

.offcanvas-item:last-child {
    border-bottom: none;
}

.offcanvas-item:active {
    background-color: var(--color-base-300);
}

.offcanvas-item.active {
    color: var(--color-primary);
    font-weight: 500;
}

/* Триггер-кнопка для offcanvas (вместо select) */
.offcanvas-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.9rem 1.1rem;
    background-color: var(--color-base-200);
    border: 1.5px solid var(--color-base-300);
    border-radius: 0.875rem;
    color: var(--color-base-content);
    font-size: 0.9375rem;
    font-weight: 500;
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

.offcanvas-trigger:active {
    background-color: var(--color-base-300);
}

.offcanvas-trigger:focus {
    border-color: var(--color-primary);
    outline: none;
}

.offcanvas-trigger:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.offcanvas-trigger .text-muted-hint {
    opacity: 0.45;
}

/* Иконка-префикс внутри триггера */
.offcanvas-trigger .trigger-icon {
    color: var(--color-primary);
    font-size: 1rem;
    flex-shrink: 0;
}

/* Селект в стиле тёмной темы приложения (для карточек на тёмном фоне) */
.form-select-base {
    background-color: var(--color-base-300) !important;
    color: var(--color-base-content) !important;
    border: 1px solid var(--color-base-300) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23999999' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
}

.form-select-base:focus {
    background-color: var(--color-base-300) !important;
    color: var(--color-base-content) !important;
    border-color: var(--color-primary) !important;
}

.form-select-base option {
    background-color: var(--color-base-300);
    color: var(--color-base-content);
}

.code-input {
    background-color: var(--color-base-content) !important;
    color: oklch(0.269 0 89.876) !important;
    border: 1px solid var(--color-base-300) !important;
    border-radius: 0.75rem !important;
    width: 50px !important;
    height: 50px !important;
    padding: 0 !important;
    text-align: center !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    box-sizing: border-box !important;
    box-shadow: none !important;
}

.code-input:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 1px var(--color-primary) !important;
    outline: none !important;
}

.table-custom {
    width: 100%;
    border-collapse: collapse;
}

.table-custom thead {
    background: var(--color-base-300);
}

.table-custom th {
    text-align: left;
    font-weight: 400;
    font-size: 0.75rem;
    opacity: 0.7;
    padding: 0.75rem 1rem;
}

.table-custom td {
    padding: 0.75rem 1rem;
}

.table-custom tbody tr + tr td {
    border-top: 1px solid color-mix(in srgb, var(--color-base-content) 10%, transparent);
}

.table-custom tbody tr:nth-child(odd) {
    color: var(--color-primary);
}

.table-custom tbody tr:nth-child(even) {
    color: var(--color-base-content);
}

.table-custom .text-center {
    text-align: center;
}

.table-custom .text-end {
    text-align: right;
}

.progress-custom {
    width: 100%;
    height: 10px;
    background: var(--color-base-300);
    border-radius: 999px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background: var(--color-primary);
    border-radius: 999px;
    transition: width 0.4s ease;
}

.hide-scrollbar {
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.hide-scrollbar::-webkit-scrollbar {
    display: none;
}