/* Button Styles */

/* Compact grid for buttons */
.compact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 5px;
    width: 100%;
    padding: 0;
    margin-bottom: 0;
    align-items: start;
}

/* Panel-specific grids */
#conditions .compact-grid {
    grid-template-columns: repeat(auto-fill, minmax(95px, 1fr));
}

#combat-actions .compact-grid {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
}

/* Compact button style */
.compact-button {
    position: relative;
    padding: 8px 10px;
    border-radius: 6px;
    text-align: left;
    font-weight: bold;
    font-size: 0.85rem;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    border: none;
    overflow: visible;
    min-height: 36px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    outline: none;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    background-color: #375E79; /* Default button color */
    color: white;
}

.compact-button:before {
    content: "";
}

.compact-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
}

.compact-button:active {
    transform: translateY(1px);
}

/* Button color variations */
.compact-button.sapphire {
    background-color: var(--color-sapphire);
}
.compact-button.sapphire:hover {
    background-color: #2d4d64;
}

.compact-button.emerald {
    background-color: var(--color-emerald);
}
.compact-button.emerald:hover {
    background-color: #2e5941;
}

.compact-button.amethyst {
    background-color: var(--color-amethyst);
}
.compact-button.amethyst:hover {
    background-color: #584360;
}

.compact-button.ruby {
    background-color: var(--color-ruby);
}
.compact-button.ruby:hover {
    background-color: #652f32;
}

.compact-button.topaz {
    background-color: var(--color-topaz);
}
.compact-button.topaz:hover {
    background-color: #8a652f;
}

.compact-button.garnet {
    background-color: var(--color-garnet);
}
.compact-button.garnet:hover {
    background-color: #4e2c30;
}

/* Theme-based button styles */
.panel-theme-emerald .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-emerald .compact-button:hover {
    background-color: #2e5941;
}

.panel-theme-sapphire .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-sapphire .compact-button:hover {
    background-color: #2d4d64;
}

.panel-theme-ruby .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-ruby .compact-button:hover {
    background-color: #652f32;
}

.panel-theme-amethyst .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-amethyst .compact-button:hover {
    background-color: #584360;
}

.panel-theme-topaz .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-topaz .compact-button:hover {
    background-color: #8a652f;
}

.panel-theme-garnet .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-garnet .compact-button:hover {
    background-color: #4e2c30;
}

.panel-theme-slate .compact-button {
    background-color: var(--panel-color);
}
.panel-theme-slate .compact-button:hover {
    background-color: #4b5a68;
}

/* Button icon styling */
.button-icon {
    width: 18px;
    height: 18px;
    margin-right: 8px;
    vertical-align: middle;
    filter: brightness(0) invert(1); /* Make icons white */
}

/* Compact item styling (for conditions, etc.) */
.compact-item {
    position: relative;
    padding: 6px 8px;
    background-color: #EDE6D9;
    border-radius: 8px;
    text-align: left;
    font-weight: bold;
    font-size: 0.8rem;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
    border: none;
    overflow: visible;
    min-height: 32px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    outline: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Icon container in items */
.icon-container {
    width: 20px;
    height: 20px;
    margin-right: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.condition-icon {
    width: 18px;
    height: 18px;
    filter: brightness(0);
    opacity: 0.7;
}

#combat-actions .condition-icon {
    width: 16px;
    height: 16px;
    filter: brightness(0);
    opacity: 0.9;
}

#movement-position .condition-icon {
    width: 16px;
    height: 16px;
    filter: brightness(0);
    opacity: 0.6;
}

.condition-name {
    font-size: 0.75rem;
    font-weight: bold;
    color: #222;
    flex: 1;
    text-align: left;
}

/* Hover effects for items */
.compact-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.15);
    background-color: #e0d9cc;
    z-index: 5;
}

/* Condition color coding */
.blinded, .invisible, .petrified { background-color: #D7DAD1; }
.charmed, .stunned, .paralyzed { background-color: #CFCACA; }
.deafened, .frightened, .grappled { background-color: #DDD4CC; }
.incapacitated, .poisoned, .prone, .restrained, .unconscious { background-color: #EDE6D9; }

/* Combat actions styling */
#combat-actions .compact-item {
    padding: 5px 8px;
    min-height: 28px;
}

#combat-actions .compact-item:nth-child(odd) {
    background-color: #f1f1f1;
}

#combat-actions .compact-item:nth-child(even) {
    background-color: #e8e8e8;
}

#combat-actions .compact-item:hover, #conditions .compact-item:hover {
    background-color: #d9d9d9;
}

/* Action tag */
.action-tag {
    font-size: 0.6rem;
    padding: 1px 4px;
    background: #1a3d5a;
    color: white;
    border-radius: 3px;
    margin-left: auto;
    text-transform: uppercase;
    letter-spacing: 0.5px;
} 