/**
 * Comunicati LND Widget Styles
 *
 * Standalone CSS for embeddable widgets
 * Uses BEM methodology for scoping
 * Neo-Brutalist Design System - LND Lazio Corporate Colors
 */

/* ========================================
   ALPINE.JS UTILITIES
   ======================================== */
[x-cloak] {
    display: none !important;
}

/* ========================================
   CSS CUSTOM PROPERTIES
   ======================================== */
.comunicati-widget {
    --lnd-blue: #00559B;
    --lnd-light: #00AEEF;
    --lnd-border: 2px;
    --lnd-border-thick: 4px;
}

/* ========================================
   WIDGET CONTAINER
   ======================================== */
.comunicati-widget {
    container-type: inline-size !important;
    container-name: comunicati-widget !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    color: #1e293b !important;
    line-height: 1.5 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

.comunicati-widget *,
.comunicati-widget *::before,
.comunicati-widget *::after {
    box-sizing: border-box !important;
}

/* ========================================
   WIDGET HEADER
   ======================================== */
.comunicati-widget__header {
    margin-bottom: 2rem !important;
    padding-bottom: 2rem !important;
    border-bottom: var(--lnd-border-thick) solid var(--lnd-blue) !important;
}

.comunicati-widget__title {
    font-size: 2rem !important;
    font-weight: 900 !important;
    color: var(--lnd-blue) !important;
    margin: 0 0 1rem 0 !important;
    text-transform: uppercase !important;
    letter-spacing: -0.05em !important;
    line-height: 1 !important;
}

.comunicati-widget__title-accent {
    color: var(--lnd-light) !important;
}

.comunicati-widget__subtitle {
    font-size: 0.625rem !important;
    font-weight: 700 !important;
    color: #94a3b8 !important;
    margin: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3em !important;
}

/* ========================================
   FILTER
   ======================================== */
.comunicati-widget__filter-bar {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: stretch !important;
    gap: 0.25rem !important;
    margin-top: 1rem !important;
    margin-bottom: 2rem !important;
}

.comunicati-widget__filter {
    position: relative !important;
    flex-shrink: 0 !important;
}

.comunicati-widget__filter-button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    height: 100% !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: var(--lnd-blue) !important;
    background-color: #ffffff !important;
    border: var(--lnd-border) solid #e2e8f0 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    transition: all 200ms ease-in-out !important;
}

.comunicati-widget__filter-button:hover {
    background-color: var(--lnd-light) !important;
    color: #ffffff !important;
    border-color: var(--lnd-light) !important;
}

.comunicati-widget__filter-button--active {
    background-color: var(--lnd-blue) !important;
    color: #ffffff !important;
    border-color: var(--lnd-blue) !important;
}

.comunicati-widget__filter-button:hover .comunicati-widget__filter-badge {
    background-color: #ffffff !important;
    color: var(--lnd-blue) !important;
}

.comunicati-widget__filter-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 1.25rem !important;
    height: 1.25rem !important;
    font-size: 0.75rem !important;
    font-weight: 900 !important;
    color: #ffffff !important;
    background-color: var(--lnd-blue) !important;
    border-radius: 0 !important;
    transition: all 200ms ease-in-out !important;
}

.comunicati-widget__filter-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    margin-top: 0.25rem !important;
    min-width: 12rem !important;
    max-height: 384px !important;
    overflow-y: auto !important;
    background-color: #ffffff !important;
    border: var(--lnd-border) solid var(--lnd-blue) !important;
    border-radius: 0 !important;
    box-shadow: 4px 4px 0px 0px rgba(0, 85, 155, 0.1) !important;
    z-index: 50 !important;
}

.comunicati-widget__filter-option {
    display: block !important;
    width: 100% !important;
    padding: 0.75rem 1rem !important;
    text-align: left !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: #64748b !important;
    background-color: transparent !important;
    border: none !important;
    border-bottom: 1px solid #f1f5f9 !important;
    cursor: pointer !important;
    transition: all 150ms ease-in-out !important;
}

.comunicati-widget__filter-option:last-child {
    border-bottom: 0 !important;
}

.comunicati-widget__filter-option:hover {
    background-color: #e0f4ff !important;
    color: var(--lnd-blue) !important;
}

.comunicati-widget__filter-option--active {
    background-color: var(--lnd-blue) !important;
    color: #ffffff !important;
}

.comunicati-widget__reset-button {
    margin-left: auto !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--lnd-blue) !important;
    background-color: #ffffff !important;
    border: var(--lnd-border) solid #e2e8f0 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    transition: all 200ms ease-in-out !important;
}

.comunicati-widget__reset-button:hover {
    background-color: var(--lnd-blue) !important;
    color: #ffffff !important;
    border-color: var(--lnd-blue) !important;
}

/* Search Bar */
.comunicati-widget__search {
    position: relative !important;
    flex: 1 !important;
    margin-bottom: 0 !important;
}

.comunicati-widget__search-icon {
    display: none !important;
}

.comunicati-widget__search-input {
    width: 100% !important;
    height: 100% !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    color: #1e293b !important;
    background-color: #f8fafc !important;
    border: var(--lnd-border) solid #e2e8f0 !important;
    border-radius: 0 !important;
    transition: all 150ms ease-in-out !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.comunicati-widget__search-input::placeholder {
    color: #cbd5e1 !important;
}

.comunicati-widget__search-input:focus {
    outline: none !important;
    border-color: var(--lnd-blue) !important;
    background-color: #ffffff !important;
}

/* Date Filter Button */
.comunicati-widget__date-button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    height: 100% !important;
    padding: 0.5rem 1rem !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: var(--lnd-blue) !important;
    background-color: #ffffff !important;
    border: var(--lnd-border) solid #e2e8f0 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    transition: all 200ms ease-in-out !important;
}

.comunicati-widget__date-button:hover {
    background-color: var(--lnd-light) !important;
    color: #ffffff !important;
    border-color: var(--lnd-light) !important;
}

.comunicati-widget__date-button:hover .comunicati-widget__filter-badge {
    background-color: #ffffff !important;
    color: var(--lnd-blue) !important;
}

/* Date Modal */
.comunicati-widget__modal-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.comunicati-widget__modal {
    background-color: #FFFFFF;
    border-radius: 0.5rem;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    max-width: 32rem;
    width: 100%;
    z-index: 101;
}

.comunicati-widget__modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.5rem;
    border-bottom: 1px solid #E5E7EB;
}

.comunicati-widget__modal-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: #111827;
    margin: 0;
}

.comunicati-widget__modal-close {
    color: #9CA3AF;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: color 150ms ease-in-out;
}

.comunicati-widget__modal-close:hover {
    color: #6B7280;
}

.comunicati-widget__modal-close svg {
    width: 1.5rem;
    height: 1.5rem;
}

.comunicati-widget__modal-body {
    padding: 1.5rem;
}

.comunicati-widget__date-field {
    margin-bottom: 1rem;
}

.comunicati-widget__date-field:last-child {
    margin-bottom: 0;
}

.comunicati-widget__date-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: #374151;
    margin-bottom: 0.5rem;
}

.comunicati-widget__date-input {
    width: 100% !important;
    padding: 0.5rem 0.75rem !important;
    font-size: 0.875rem !important;
    color: #374151 !important;
    background-color: #FFFFFF !important;
    border: 1px solid #D1D5DB !important;
    border-radius: 0.5rem !important;
    transition: border-color 150ms ease-in-out, box-shadow 150ms ease-in-out !important;
}

.comunicati-widget__date-input:focus {
    outline: none !important;
    border-color: #0067A5 !important;
    box-shadow: 0 0 0 3px rgba(0, 103, 165, 0.1) !important;
}

.comunicati-widget__modal-footer {
    display: flex;
    flex-direction: row-reverse;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    background-color: #F9FAFB;
    border-top: 1px solid #E5E7EB;
}

.comunicati-widget__modal-button {
    padding: 0.5rem 1rem !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    border-radius: 0.5rem !important;
    cursor: pointer !important;
    transition: all 150ms ease-in-out !important;
}

.comunicati-widget__modal-button--primary {
    color: #FFFFFF !important;
    background-color: #0067A5 !important;
    border: none !important;
}

.comunicati-widget__modal-button--primary:hover {
    background-color: #005A91 !important;
}

.comunicati-widget__modal-button--secondary {
    color: #374151 !important;
    background-color: #FFFFFF !important;
    border: 1px solid #D1D5DB !important;
}

.comunicati-widget__modal-button--secondary:hover {
    background-color: #F9FAFB !important;
}

/* ========================================
   COMMUNICATION CARD
   ======================================== */
.comunicati-widget__card {
    display: flex !important;
    flex-direction: column !important;
    background-color: #ffffff !important;
    border: var(--lnd-border) solid var(--lnd-blue) !important;
    border-radius: 0 !important;
    margin-bottom: 1.5rem !important;
    overflow: hidden !important;
    transition: all 200ms ease-in-out !important;
    width: 100% !important;
}

.comunicati-widget__card:hover {
    box-shadow: 8px 8px 0px 0px rgba(0, 85, 155, 0.1) !important;
}

.comunicati-widget__card-content {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
    width: 100% !important;
}

/* ========================================
   CARD DATE BLOCK (left sidebar)
   ======================================== */
.comunicati-widget__date-block {
    width: 4rem !important;
    background-color: var(--lnd-blue) !important;
    padding: 1rem 0.5rem !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    border-right: var(--lnd-border) solid var(--lnd-blue) !important;
}

.comunicati-widget__date-month {
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    color: var(--lnd-light) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.15em !important;
    margin-bottom: 0.25rem !important;
    text-align: center !important;
    line-height: 1 !important;
}

.comunicati-widget__date-day {
    font-size: 1.5rem !important;
    font-weight: 900 !important;
    color: #ffffff !important;
    line-height: 1 !important;
    letter-spacing: -0.05em !important;
    text-align: center !important;
}

/* ========================================
   CARD HEADER (metadata badges)
   ======================================== */
.comunicati-widget__card-header {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-bottom: 0.75rem !important;
    font-size: 0.75rem !important;
    flex-wrap: wrap !important;
}

.comunicati-widget__badge {
    display: inline-flex !important;
    align-items: center !important;
    padding: 0.25rem 0.75rem !important;
    border-radius: 0 !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: #ffffff !important;
    background-color: #f59e0b !important;
    border-left: var(--lnd-border) solid #d97706 !important;
}

.comunicati-widget__badge--department {
    background-color: #e0f4ff !important;
    color: var(--lnd-blue) !important;
    border-left-color: var(--lnd-blue) !important;
}

.comunicati-widget__badge--competition {
    background-color: #f1f5f9 !important;
    color: #64748b !important;
    border-left-color: #cbd5e1 !important;
}

.comunicati-widget__meta {
    font-size: 0.625rem !important;
    font-weight: 700 !important;
    color: #94a3b8 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

/* ========================================
   CARD BODY
   ======================================== */
.comunicati-widget__card-body {
    flex: 1 1 0% !important;
    padding: 1.5rem !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    min-width: 0 !important;
}

.comunicati-widget__subject {
    font-size: 1rem !important;
    font-weight: 900 !important;
    color: var(--lnd-blue) !important;
    margin: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: -0.02em !important;
    line-height: 1.3 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.comunicati-widget__summary {
    font-size: 0.75rem !important;
    font-weight: 500 !important;
    color: #64748b !important;
    margin: 0.5rem 0 0 0 !important;
    font-style: italic !important;
    letter-spacing: 0.02em !important;
    line-height: 1.5 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 1 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* ========================================
   ACTION BUTTONS
   ======================================== */
.comunicati-widget__actions-wrapper {
    margin-top: 1rem !important;
}

.comunicati-widget__actions {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-bottom: 0.75rem !important;
}

/* Base button styles */
.comunicati-widget__btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.375rem !important;
    padding: 0.375rem 0.75rem !important;
    font-size: 0.5625rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    border: 2px solid !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    transition: all 150ms ease-in-out !important;
    text-decoration: none !important;
    height: 1.75rem !important;
}

/* Attachments button - gray with border */
.comunicati-widget__btn--attachments {
    background-color: #f1f5f9 !important;
    color: #64748b !important;
    border-color: #cbd5e1 !important;
}

.comunicati-widget__btn--attachments:hover {
    background-color: #e2e8f0 !important;
    color: #475569 !important;
}

/* Download button - light blue */
.comunicati-widget__btn--download {
    background-color: var(--lnd-light) !important;
    color: #ffffff !important;
    border-color: var(--lnd-light) !important;
}

.comunicati-widget__btn--download:hover {
    background-color: #0099d6 !important;
    border-color: #0099d6 !important;
}

.comunicati-widget__btn-icon {
    font-size: 0.5625rem !important;
    line-height: 1 !important;
}

.comunicati-widget__btn-chevron {
    width: 0.75rem !important;
    height: 0.75rem !important;
    transition: transform 200ms ease-in-out !important;
    transform-origin: center !important;
}

.comunicati-widget__btn-chevron--rotated {
    transform: rotate(180deg) !important;
}

/* ========================================
   ATTACHMENTS LIST
   ======================================== */
.comunicati-widget__attachments-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
    padding-top: 0.75rem !important;
    margin-top: 0 !important;
    border-top: 1px solid #f1f5f9 !important;
    width: 100% !important;
}

.comunicati-widget__attachment-item {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    text-decoration: none !important;
    transition: opacity 150ms ease-in-out !important;
}

.comunicati-widget__attachment-item:hover {
    opacity: 0.8 !important;
}

.comunicati-widget__attachment-icon {
    font-size: 0.625rem !important;
    color: #94a3b8 !important;
    flex-shrink: 0 !important;
}

.comunicati-widget__attachment-link {
    font-size: 0.6875rem !important;
    color: #3b82f6 !important;
    font-weight: 500 !important;
    word-break: break-word !important;
}

/* ========================================
   PAGINATION
   ======================================== */
.comunicati-widget__pagination {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-top: 2rem !important;
    padding-top: 2rem !important;
    border-top: var(--lnd-border) solid #e2e8f0 !important;
}

.comunicati-widget__pagination-btn {
    padding: 0.5rem 1rem !important;
    background-color: #ffffff !important;
    border: var(--lnd-border) solid var(--lnd-blue) !important;
    border-radius: 0 !important;
    color: var(--lnd-blue) !important;
    font-size: 0.625rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    cursor: pointer !important;
    transition: all 200ms ease-in-out !important;
}

.comunicati-widget__pagination-btn:hover:not(:disabled) {
    background-color: var(--lnd-blue) !important;
    color: #ffffff !important;
}

.comunicati-widget__pagination-btn:disabled {
    opacity: 0.3 !important;
    cursor: not-allowed !important;
}

.comunicati-widget__pagination-info {
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    color: #64748b !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

/* ========================================
   LOADING STATE
   ======================================== */
.comunicati-widget__loading {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 4rem 1rem !important;
}

.comunicati-widget__inline-loading {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 2rem 1rem !important;
    opacity: 0.6 !important;
}

.comunicati-widget__spinner {
    width: 3rem !important;
    height: 3rem !important;
    border: 4px solid #e2e8f0 !important;
    border-top-color: var(--lnd-blue) !important;
    border-radius: 0 !important;
    animation: comunicati-widget-spin 1s linear infinite !important;
}

@keyframes comunicati-widget-spin {
    to {
        transform: rotate(360deg) !important;
    }
}

/* ========================================
   EMPTY STATE
   ======================================== */
.comunicati-widget__empty {
    padding: 4rem 1rem !important;
    text-align: center !important;
    border: 2px dashed #cbd5e1 !important;
    border-radius: 0 !important;
}

.comunicati-widget__empty-icon {
    width: 3rem !important;
    height: 3rem !important;
    color: #cbd5e1 !important;
    margin: 0 auto 1rem !important;
}

.comunicati-widget__empty-title {
    font-size: 0.875rem !important;
    font-weight: 700 !important;
    color: #64748b !important;
    margin: 0 0 0.5rem 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
}

.comunicati-widget__empty-message {
    font-size: 0.875rem !important;
    color: #94a3b8 !important;
    margin: 0 !important;
}

/* ========================================
   RESPONSIVE - Container Queries
   ======================================== */

/* Mobile - stacked layout */
@container comunicati-widget (max-width: 640px) {
    .comunicati-widget__title {
        font-size: 1.5rem !important;
    }

    .comunicati-widget__date-block {
        width: 3rem !important;
        padding: 0.75rem 0.25rem !important;
    }

    .comunicati-widget__date-month {
        font-size: 0.5rem !important;
    }

    .comunicati-widget__date-day {
        font-size: 1.25rem !important;
    }

    .comunicati-widget__card-body {
        padding: 1rem !important;
    }

    .comunicati-widget__subject {
        font-size: 0.75rem !important;
    }

    .comunicati-widget__summary {
        font-size: 0.625rem !important;
    }

    .comunicati-widget__badge {
        font-size: 0.5rem !important;
        padding: 0.2rem 0.5rem !important;
    }

    .comunicati-widget__meta {
        font-size: 0.5rem !important;
    }

    .comunicati-widget__btn {
        font-size: 0.5rem !important;
        padding: 0.3rem 0.5rem !important;
        height: 1.5rem !important;
        gap: 0.25rem !important;
    }

    .comunicati-widget__btn-icon {
        font-size: 0.5rem !important;
    }

    .comunicati-widget__btn-chevron {
        width: 0.625rem !important;
        height: 0.625rem !important;
    }

    .comunicati-widget__filter-button,
    .comunicati-widget__date-button,
    .comunicati-widget__reset-button {
        font-size: 0.5rem !important;
        padding: 0.375rem 0.5rem !important;
    }

    .comunicati-widget__search-input {
        font-size: 0.5rem !important;
        padding: 0.375rem 0.5rem !important;
    }

    .comunicati-widget__search {
        flex-basis: 100% !important;
        width: 100% !important;
    }
}

/* Tablet and up */
@container comunicati-widget (min-width: 641px) {
    .comunicati-widget__date-block {
        width: 5rem !important;
    }

    .comunicati-widget__date-month {
        font-size: 0.75rem !important;
    }

    .comunicati-widget__date-day {
        font-size: 2rem !important;
    }

    .comunicati-widget__subject {
        font-size: 1.25rem !important;
    }

    .comunicati-widget__btn {
        font-size: 0.625rem !important;
        padding: 0.5rem 1rem !important;
        height: 2rem !important;
    }
}

/* ========================================
   UTILITY CLASSES
   ======================================== */
.comunicati-widget__hidden {
    display: none !important;
}
