/* ============================================================================
 * FC Portal — gemensamma UI-utilities (delade komponenter)
 *
 * Innehåller återanvändbara byggblock som inte är knutna till en specifik
 * app/sida. Renderas alltid via base.html så de finns globalt.
 *
 * Sektioner:
 *   - Skeleton-loader (.fc-skeleton-*) — visuell platshållare för async-data
 *
 * När fler delade komponenter tillkommer (badges, chips, etc.) lägg dem här
 * istället för i sid-specifik CSS för att undvika dubbla definitioner.
 * ========================================================================= */


/* ----------------------------------------------------------------------------
 * Skeleton-loader
 *
 * Använd när du väntar in asynkront innehåll och vill ge visuell feedback
 * att något händer — utan layout-shift när svaret renderas.
 *
 * Renderas via helper `fcShowSkeleton(containerId, rowCount, options)` i
 * request_handler.js (rekommenderat), eller manuellt genom att skriva ut
 * `.fc-skeleton-block` med n stycken `.fc-skeleton-row` inuti.
 *
 * Designval: subtil grå-shimmer (≈1.5s loop) — tillräckligt animerad för
 * att kommunicera aktivitet utan att vara distraherande. Stöd för
 * `prefers-reduced-motion` är inbyggt.
 * ---------------------------------------------------------------------------- */

.fc-skeleton-block {
    /* Vertikalt utrymme matchar typisk modal-body / drawer-sektion. */
    padding: 4px 0;
}

.fc-skeleton-row {
    /* Höjden matchar en standard precheck-/list-rad så det inte blir
       layout-shift när innehållet poppar in. Width sätts per rad
       (inline) för att simulera variation. */
    height: 14px;
    margin-bottom: 12px;
    border-radius: 4px;
    background: linear-gradient(
        90deg,
        #edeef1 0%,
        #f5f6f8 50%,
        #edeef1 100%
    );
    background-size: 200% 100%;
    animation: fc-skeleton-shimmer 1.5s ease-in-out infinite;
}

.fc-skeleton-row:last-child {
    margin-bottom: 0;
}

/* Variant: större rad som efterliknar en "card" / list-item. */
.fc-skeleton-row--tall {
    height: 56px;
    border-radius: 6px;
    margin-bottom: 10px;
}

/* Variant: liten rad (subtitle / metadata). */
.fc-skeleton-row--small {
    height: 10px;
    margin-bottom: 8px;
}

@keyframes fc-skeleton-shimmer {
    0%   { background-position: 100% 0; }
    100% { background-position: -100% 0; }
}

/* Tillgänglighet: respektera användarens motion-preferens.
   Behåll en lugn statisk grå-ton istället för animation. */
@media (prefers-reduced-motion: reduce) {
    .fc-skeleton-row,
    .fc-skeleton-row--tall,
    .fc-skeleton-row--small {
        animation: none;
        background: #edeef1;
    }
}


/* ----------------------------------------------------------------------------
 * Spinner (Material-arc) — portalens ENDA spinner
 *
 * Använd för indeterminate / process- / helsides-laddning: formulär-submit,
 * "Skapar fakturor…", status-hämtning, stora formulärs overlay. För
 * innehållsformat (listor, tabeller, modal-/drawer-kroppar, detaljpaneler)
 * använd skeleton-loadern ovan istället — den ger inget layout-hopp.
 *
 * Roterande SVG-ring där bågen växer och krymper (Googles Material-stil) —
 * tydligt mer levande än en enkel border-spin, men fortfarande lugn. Färgen
 * ärvs via `currentColor` så spinnern automatiskt matchar sin kontext
 * (mörk slate i neutrala ytor, banderollens ton i .fp-running, knappens
 * textfärg i en knapp).
 *
 * Återanvänds via markup
 *   <svg class="fc-spinner" viewBox="0 0 44 44" aria-hidden="true">
 *     <circle cx="22" cy="22" r="18"></circle></svg>
 * eller JS-helpern `fcSpinner(size)` i request_handler.js (enda källan).
 * Storlekar: default 40px, `.fc-spinner--sm` 18px (inline/knapp),
 * `.fc-spinner--lg` 52px.
 * ---------------------------------------------------------------------------- */
.fc-spinner {
    width: 40px;
    height: 40px;
    /* Ingen egen color → ärver currentColor från kontexten. */
    animation: fc-spinner-rotate 1.4s linear infinite;
}
.fc-spinner circle {
    fill: none;
    stroke: currentColor;
    stroke-width: 4;
    stroke-linecap: round;
    stroke-dasharray: 90, 150;
    stroke-dashoffset: 0;
    animation: fc-spinner-dash 1.4s ease-in-out infinite;
}
.fc-spinner--sm { width: 18px; height: 18px; vertical-align: middle; }
.fc-spinner--sm circle { stroke-width: 5; }
.fc-spinner--lg { width: 52px; height: 52px; }

@keyframes fc-spinner-rotate {
    100% { transform: rotate(360deg); }
}
@keyframes fc-spinner-dash {
    0%   { stroke-dasharray: 1, 150;  stroke-dashoffset: 0; }
    50%  { stroke-dasharray: 90, 150; stroke-dashoffset: -35; }
    100% { stroke-dasharray: 90, 150; stroke-dashoffset: -124; }
}

/* Tillgänglighet: dämpa pulsningen och sakta ner rotationen vid
   reduced-motion. Behåll en lugn, fast båge som fortfarande snurrar
   (en helt fryst delbåge ser trasig ut). */
@media (prefers-reduced-motion: reduce) {
    .fc-spinner { animation-duration: 2.4s; }
    .fc-spinner circle {
        animation: none;
        stroke-dasharray: 70, 150;
    }
}
