:root {
    --color-primary: #111A2D;
    --color-primary-hover: #293142;
    --color-primary-focus: #414857;
    /* Two distinct soft levels (important!) */
    --color-primary-soft: #EEF0F4;          /* Card hover */
    --color-primary-soft-strong: #E2E5EC;   /* Icon circle hover */
    --color-primary-text: #111A2D;
    --color-primary-pulse: #111A2D; /* RGB of #111A2D */
}

/* ===== Backgrounds ===== */

.bg-primary {
    background-color: var(--color-primary);
}

.bg-primary-hover:hover {
    background-color: var(--color-primary-hover);
}

/* Card hover */
.bg-primary-soft-hover:hover {
    background-color: var(--color-primary-soft);
}

/* Base icon circle background (Tailwind gray-100 equivalent) */
.bg-primary-circle {
    background-color: #f3f4f6;
}

.bg-primary-soft-strong {
    background-color: var(--color-primary-soft-strong);
}

/* ===== Borders ===== */
.border-primary {
    border-color: var(--color-primary);
}

.border-primary-hover:hover {
    border-color: var(--color-primary-focus);
}

/* ===== Text ===== */

.text-primary {
    color: var(--color-primary-text);
}

.text-primary-hover:hover {
    color: var(--color-primary);
}

/* ===== Group hover utilities ===== */

/* Icon circle hover (stronger than card) */
.group:hover .group-hover-bg-primary-soft {
    background-color: var(--color-primary-soft-strong);
}

/* Icon + label text */
.group:hover .group-hover-text-primary {
    color: var(--color-primary);
}

/* ===== Inputs (Tailwind-style focus ring) ===== */

input:focus,
select:focus,
textarea:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
    border-color: var(--color-primary-focus);
    box-shadow:
        0 0 0 1px var(--color-primary-focus),
        0 0 0 3px rgba(65, 72, 87, 0.35);
}

 .rotate-90{transform:rotate(90deg);}

@keyframes pulseHighlight {
    0% {
        box-shadow: 0 0 0 0 rgba(var(--color-primary-pulse), 0.4);
    }
    50% {
        box-shadow: 0 0 20px 4px rgba(var(--color-primary-pulse), 0.4);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(var(--color-primary-pulse), 0.4);
    }
}

.highlight-card {
    animation: pulseHighlight 1.6s ease-out 1;
    border-radius: 12px;
}

input[type="datetime-local"] {
    -webkit-appearance: none;
    appearance: none;
    line-height: 1.2;
}

input[type="datetime-local"]::-webkit-datetime-edit {
    padding: 0;
}

input[type="checkbox"],
input[type="radio"] {
    accent-color: var(--color-primary);
}

/* Tailwind forms plugin fallback */
input[type="checkbox"]:checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

input[type="checkbox"]:focus {
    outline: none;
    box-shadow:none;
}

input[type="radio"]:focus {
    outline: none;
    box-shadow:none;
}
