/**
 * Modern CSS for mod_currentmoon
 * Compatible with rt_salient template
 *
 * @version      2.0.0
 * @since        1.0.0
 * @package      mod_currentmoon
 * @author       Sleestaq, LLC <info@sleestaq.com>
 * @copyright    © 2021-2025 Sleestaq, LLC
 * @license      None: Sleestaq proprietary code
 */

/* Base Module Styles */
.mod-currentmoon {
    font-family: inherit;
    line-height: 1.4;
    color: inherit;
    background: transparent;
    border-radius: 8px;
    padding: 1rem;
    margin: 0;
    box-sizing: border-box;
    transition: all 0.3s ease;
}

/* Layout Variations */
.moon-layout-compact {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.moon-layout-compact .moon-image-container {
    flex-shrink: 0;
}

.moon-layout-compact .moon-info-container {
    flex: 1;
    min-width: 200px;
}

.moon-layout-detailed {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1.5rem;
    align-items: start;
}

.moon-layout-detailed .moon-image-container {
    grid-column: 1;
    grid-row: 1 / span 2;
}

.moon-layout-detailed .moon-info-container {
    grid-column: 2;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.moon-layout-minimal {
    text-align: center;
    padding: 0.5rem;
}

.moon-layout-minimal .moon-image-container {
    margin-bottom: 0.5rem;
}

.moon-layout-minimal .moon-info-container {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

/* Image Sizes */
.moon-image-small .moon-phase-image {
    width: 60px;
    height: 60px;
}

.moon-image-medium .moon-phase-image {
    width: 120px;
    height: 120px;
}

.moon-image-large .moon-phase-image {
    width: 180px;
    height: 180px;
}

/* Image Container */
.moon-image-container {
    display: flex;
    justify-content: center;
    align-items: center;
}

.moon-phase-image {
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.moon-phase-image:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* Info Container */
.moon-info-container {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Info Groups */
.moon-phase-info,
.moon-illumination-info,
.moon-age-info,
.moon-distance-info,
.moon-diameter-info {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.moon-astronomical-info {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

/* Labels and Values */
.moon-label {
    font-size: 0.875rem;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.7);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.moon-value {
    font-size: 1rem;
    font-weight: 500;
    color: inherit;
}

.phase-name {
    font-weight: 600;
    color: #2c3e50;
}

.illumination-percentage {
    font-weight: 600;
    color: #e74c3c;
}

.age-value {
    color: #3498db;
}

.distance-value,
.diameter-value {
    color: #7f8c8d;
    font-family: monospace;
}

/* Illumination Bar (Detailed Layout) */
.illumination-bar {
    width: 100%;
    height: 8px;
    background-color: rgba(0, 0, 0, 0.1);
    border-radius: 4px;
    overflow: hidden;
    margin-top: 0.25rem;
}

.illumination-fill {
    height: 100%;
    background: linear-gradient(90deg, #e74c3c, #f39c12);
    border-radius: 4px;
    transition: width 0.5s ease;
}

/* Error States */
.moon-phase-error {
    padding: 1rem;
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
    border-radius: 4px;
    text-align: center;
    font-size: 0.875rem;
}

/* Location Information Styles */
.moon-location-info {
    margin-top: 1rem;
    padding: 0.75rem;
    background: var(--moon-location-bg, rgba(255, 255, 255, 0.05));
    border-radius: var(--moon-border-radius, 8px);
    border: 1px solid var(--moon-location-border, rgba(255, 255, 255, 0.1));
    font-size: 0.875rem;
}

.moon-location-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font-weight: 600;
    color: var(--moon-location-header-color, #e2e8f0);
}

.moon-location-icon {
    font-size: 1rem;
    opacity: 0.8;
}

.moon-location-title {
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.moon-timezone,
.moon-local-time,
.moon-coordinates,
.moon-detection-method {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.25rem 0;
    border-bottom: 1px solid var(--moon-location-divider, rgba(255, 255, 255, 0.05));
}

.moon-timezone:last-child,
.moon-local-time:last-child,
.moon-coordinates:last-child,
.moon-detection-method:last-child {
    border-bottom: none;
}

.moon-timezone-label,
.moon-local-time-label,
.moon-coordinates-label,
.moon-detection-method-label {
    font-weight: 500;
    color: var(--moon-location-label-color, #94a3b8);
    font-size: 0.8rem;
}

.moon-timezone-value,
.moon-local-time-value,
.moon-coordinates-value,
.moon-detection-method-value {
    font-weight: 600;
    color: var(--moon-location-value-color, #f1f5f9);
    font-size: 0.8rem;
    text-align: right;
}

/* Responsive location info */
@media (max-width: 768px) {
    .moon-location-info {
        margin-top: 0.75rem;
        padding: 0.5rem;
    }

    .moon-timezone,
    .moon-local-time,
    .moon-coordinates,
    .moon-detection-method {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
    }

    .moon-timezone-value,
    .moon-local-time-value,
    .moon-coordinates-value,
    .moon-detection-method-value {
        text-align: left;
    }
}

/* Responsive Design */
@media (max-width: 768px) {
    .moon-layout-compact {
        flex-direction: column;
        text-align: center;
    }

    .moon-layout-detailed {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .moon-layout-detailed .moon-image-container {
        grid-column: 1;
        grid-row: 1;
        justify-self: center;
    }

    .moon-layout-detailed .moon-info-container {
        grid-column: 1;
        grid-row: 2;
    }

    .moon-image-large .moon-phase-image {
        width: 120px;
        height: 120px;
    }
}

@media (max-width: 480px) {
    .mod-currentmoon {
        padding: 0.75rem;
    }

    .moon-image-medium .moon-phase-image,
    .moon-image-large .moon-phase-image {
        width: 80px;
        height: 80px;
    }

    .moon-label {
        font-size: 0.75rem;
    }

    .moon-value {
        font-size: 0.875rem;
    }
}

/* Animation Support */
.moon-animations-enabled {
    opacity: 1;
    transform: translateY(0);
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    .moon-phase-image {
        border: 2px solid currentColor;
    }

    .illumination-bar {
        background-color: currentColor;
    }

    .illumination-fill {
        background-color: currentColor;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {

    .mod-currentmoon,
    .moon-phase-image,
    .illumination-fill {
        transition: none;
    }

    .moon-animations-enabled {
        opacity: 1;
        transform: none;
    }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
    .mod-currentmoon {
        color: #ffffff;
    }

    .moon-label {
        color: rgba(255, 255, 255, 0.7);
    }

    .moon-phase-image {
        box-shadow: 0 2px 8px rgba(255, 255, 255, 0.1);
    }

    .moon-astronomical-info {
        border-top-color: rgba(255, 255, 255, 0.1);
    }

    .moon-phase-error {
        background-color: #721c24;
        color: #f8d7da;
        border-color: #f5c6cb;
    }
}

/* Dark mode location styles */
@media (prefers-color-scheme: dark) {
    .moon-location-info {
        --moon-location-bg: rgba(0, 0, 0, 0.2);
        --moon-location-border: rgba(255, 255, 255, 0.1);
        --moon-location-header-color: #f1f5f9;
        --moon-location-label-color: #94a3b8;
        --moon-location-value-color: #e2e8f0;
        --moon-location-divider: rgba(255, 255, 255, 0.1);
    }
}

/* High contrast mode */
@media (prefers-contrast: high) {
    .moon-location-info {
        border-width: 2px;
        border-color: currentColor;
    }

    .moon-timezone,
    .moon-local-time,
    .moon-coordinates,
    .moon-detection-method {
        border-bottom-width: 2px;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .moon-location-info {
        transition: none;
    }
}

/* Location Note Styles */
.moon-location-note {
    margin-top: 0.5rem;
    padding: 0.25rem 0.5rem;
    background: var(--moon-location-note-bg, rgba(255, 193, 7, 0.1));
    border-radius: 4px;
    border-left: 3px solid var(--moon-location-note-border, #ffc107);
}

.moon-location-note-text {
    color: var(--moon-location-note-color, #856404);
    font-size: 0.75rem;
    font-style: italic;
    line-height: 1.2;
}

/* Dark mode location note */
@media (prefers-color-scheme: dark) {
    .moon-location-note {
        --moon-location-note-bg: rgba(255, 193, 7, 0.15);
        --moon-location-note-border: #ffc107;
        --moon-location-note-color: #ffd54f;
    }
}

/* Print Styles */
@media print {
    .mod-currentmoon {
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .moon-phase-image {
        box-shadow: none;
        border: 1px solid #000;
    }

    .illumination-bar {
        background-color: #ccc;
    }

    .illumination-fill {
        background-color: #000;
    }
}

/* Focus States for Accessibility */
.mod-currentmoon:focus-within {
    outline: 2px solid #007cba;
    outline-offset: 2px;
}

.moon-phase-image:focus {
    outline: 2px solid #007cba;
    outline-offset: 2px;
}

/* Screen Reader Only Text */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
