/* ========================================================================
   SwissArchery Core - Design system (front-office)
   ======================================================================== */
:root {
    --saa-primary:    #385FF6;
    --saa-secondary:  #D51313;
    --saa-accent:     #f5c842;
    --saa-success:    #256B18;
    --saa-warning:    #e67e22;
    --saa-danger:     #D51313;
    --saa-event:      #5F218A;
    --saa-text:       #1f2933;
    --saa-text-muted: #5a6573;
    --saa-bg:         #ffffff;
    --saa-bg-alt:     #f5f7fa;
    --saa-border:     #d9dee5;
    --saa-radius:     6px;
    --saa-shadow:     0 1px 3px rgba(0,0,0,0.08);
    --saa-font:       -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* Base block layout */
.saa-card {
    background: var(--saa-bg);
    border: 1px solid var(--saa-border);
    border-radius: var(--saa-radius);
    box-shadow: var(--saa-shadow);
    padding: 16px;
    margin-bottom: 16px;
}

/* Buttons */
.saa-btn {
    display: inline-block;
    padding: 8px 16px;
    border: 1px solid var(--saa-border);
    border-radius: var(--saa-radius);
    text-decoration: none;
    background: var(--saa-bg);
    color: var(--saa-text);
    font-family: var(--saa-font);
    font-size: 14px;
    cursor: pointer;
    transition: background 0.15s ease, transform 0.05s ease;
}
.saa-btn:hover  { background: var(--saa-bg-alt); }
.saa-btn:active { transform: translateY(1px); }

.saa-btn--primary { background: var(--saa-primary);   color: #fff; border-color: var(--saa-primary); }
.saa-btn--success { background: var(--saa-success);   color: #fff; border-color: var(--saa-success); }
.saa-btn--danger  { background: var(--saa-danger);    color: #fff; border-color: var(--saa-danger); }
.saa-btn--accent  { background: var(--saa-accent);    color: var(--saa-text); border-color: var(--saa-accent); }

/* Tables */
.saa-table {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--saa-font);
    font-size: 14px;
    margin: 12px 0;
}
.saa-table th {
    background: var(--saa-primary);
    color: #fff;
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
}
.saa-table td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--saa-border);
}
.saa-table tr:nth-child(even) td { background: var(--saa-bg-alt); }

/* Badges */
.saa-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    color: #fff;
    background: var(--saa-text-muted);
}
.saa-badge--success    { background: var(--saa-success); }
.saa-badge--danger     { background: var(--saa-danger); }
.saa-badge--warning    { background: var(--saa-warning); }
.saa-badge--info       { background: var(--saa-primary); }
.saa-badge--confirmed  { background: var(--saa-success); }
.saa-badge--pending    { background: var(--saa-warning); }
.saa-badge--cancelled  { background: var(--saa-danger); }

/* Notices */
.saa-notice {
    border-left: 4px solid var(--saa-primary);
    background: var(--saa-bg-alt);
    padding: 10px 14px;
    margin: 12px 0;
    border-radius: 0 var(--saa-radius) var(--saa-radius) 0;
}
.saa-notice--info     { border-color: var(--saa-primary); }
.saa-notice--success  { border-color: var(--saa-success); }
.saa-notice--warning  { border-color: var(--saa-warning); background: #fff7ed; }
.saa-notice--danger   { border-color: var(--saa-danger);  background: #fff5f5; }

/* Forms */
.saa-form-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 12px;
}
.saa-form-row label {
    font-weight: 600;
    color: var(--saa-text);
}
.saa-form-row input,
.saa-form-row select,
.saa-form-row textarea {
    padding: 8px;
    border: 1px solid var(--saa-border);
    border-radius: var(--saa-radius);
    font-family: inherit;
    font-size: 14px;
}

/* Utility */
.saa-text-muted { color: var(--saa-text-muted); }
.saa-empty {
    background: var(--saa-bg-alt);
    border: 1px dashed var(--saa-border);
    padding: 16px;
    text-align: center;
    border-radius: var(--saa-radius);
    color: var(--saa-text-muted);
}

/* ==================================================================
   Global a11y, touch, responsive and PWA-ready overrides
   (added 2026-05-16, applies to every front-end SwissArchery widget)
   ================================================================== */

/* Tap targets: every actionable element must be at least 44x44 (WCAG AAA) */
.saa-btn,
.saa-action,
.saa-link,
.saa-tag,
.saa-card a,
.saa-form-row button,
.saa-form-row input[type="submit"],
.saa-form-row input[type="button"] {
    min-height: 44px;
    min-width: 44px;
}

/* Focus-visible styling, not just :hover */
.saa :focus-visible,
.saa-home :focus-visible,
.saa-form-row :focus-visible,
.saa-card :focus-visible {
    outline: 3px solid rgba(213, 19, 19, 0.55);
    outline-offset: 2px;
}

/* Responsive media defaults */
.saa img,
.saa-card img,
.saa-home img,
.saa-table img {
    max-width: 100%;
    height: auto;
}

/* Responsive tables -> cards on small screens */
@media (max-width: 768px) {
    .saa-responsive-table thead { display: none; }
    .saa-responsive-table,
    .saa-responsive-table tbody,
    .saa-responsive-table tr,
    .saa-responsive-table td {
        display: block;
        width: 100%;
    }
    .saa-responsive-table tr {
        margin-bottom: 12px;
        border: 1px solid var(--saa-border, #e2e6eb);
        border-radius: 6px;
        padding: 8px 12px;
    }
    .saa-responsive-table td {
        padding: 4px 0;
        border: none;
        text-align: right;
    }
    .saa-responsive-table td::before {
        content: attr(data-label);
        float: left;
        font-weight: 600;
        margin-right: 12px;
        color: var(--saa-text-muted, #5a6573);
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .saa,
    .saa *,
    .saa-home,
    .saa-home *,
    .saa-card,
    .saa-card * {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }
}

/* Dark mode (palette inversion baseline) */
@media (prefers-color-scheme: dark) {
    :root {
        --saa-bg: #0f1419;
        --saa-bg-alt: #161c23;
        --saa-text: #e6e9ee;
        --saa-text-muted: #9ea7b3;
        --saa-border: #2a313a;
        --saa-radius: 6px;
    }
}
