/* ============================================================================
   Amvionlie CMS
   Public Frontend Controls
   File: amvionlie_phoenix/public/assets/frontend_controls.css
   Version: v0.0003 Alpha
   Updated: 2026-05-21
   Author: K-Tech Industries, Engineering Team
   Purpose: Baseline public control styles for theme and addon consumption.
============================================================================ */

:root {
    --amv-control-radius: 8px;
    --amv-control-padding-x: 9px;
    --amv-control-padding-y: 7px;
    --amv-control-min-height: 32px;
    --amv-control-gap: 6px;
    --amv-control-border: var(--color-border, #cbd5e1);
    --amv-control-bg: var(--color-field-background, #ffffff);
    --amv-control-text: var(--color-field-text, #0f172a);
    --amv-control-muted: var(--color-muted, #64748b);
    --amv-control-focus: var(--color-field-focus, var(--color-primary, currentColor));
    --amv-control-button-bg: var(--color-button-background, #0f172a);
    --amv-control-button-border: var(--color-button-border, #0f172a);
    --amv-control-button-text: var(--color-button-text, #ffffff);
}

.amv-link,
.amv-link:visited {
    color: var(--amv-link, var(--color-primary, currentColor));
    font-weight: 400;
    text-decoration: none;
}

.amv-link:hover,
.amv-link:focus-visible,
.amv-link--strong {
    color: var(--amv-link-strong, var(--amv-link, var(--color-primary, currentColor)));
    text-decoration: underline;
}

.amv-link--muted {
    color: var(--color-muted, #64748b);
}

.amv-link--danger {
    color: var(--color-danger, #b42318);
}

.amv-link--external,
.amv-link--inline-action,
.amv-link--nav,
.amv-link--breadcrumb,
.amv-link__icon,
.amv-link__label {
    display: inline-flex;
    align-items: center;
    min-width: 0;
}

.amv-link--external,
.amv-link--inline-action,
.amv-link--nav,
.amv-link--breadcrumb {
    gap: 0.35rem;
}

.amv-link--disabled {
    color: var(--color-muted, #64748b);
    cursor: not-allowed;
    opacity: 0.7;
    pointer-events: none;
    text-decoration: none;
}

.amv-control-button {
    display: inline-flex;
    min-height: var(--amv-control-min-height);
    align-items: center;
    justify-content: center;
    gap: var(--amv-control-gap);
    border: 1px solid var(--amv-control-button-border);
    border-radius: var(--amv-control-radius);
    padding: var(--amv-control-padding-y) var(--amv-control-padding-x);
    background: var(--amv-control-button-bg);
    color: var(--amv-control-button-text);
    font: 700 14px/1.2 Arial, sans-serif;
    text-decoration: none;
    cursor: pointer;
}

.amv-control-button:hover,
.amv-control-button:focus-visible {
    border-color: var(--amv-control-focus);
    outline: 2px solid color-mix(in srgb, var(--amv-control-focus) 28%, transparent);
    text-decoration: none;
}

.amv-control-button--primary {
    background: var(--color-primary, var(--amv-control-button-bg));
    border-color: var(--color-primary, var(--amv-control-button-border));
    color: var(--color-on-primary, #ffffff);
}

.amv-control-button--secondary {
    background: var(--amv-control-bg);
    color: var(--amv-control-text);
}

.amv-control-button--danger {
    background: var(--color-danger, #b42318);
    border-color: var(--color-danger, #b42318);
    color: var(--color-on-danger, #ffffff);
}

.amv-control-button--quiet {
    border-color: transparent;
    background: transparent;
    color: var(--amv-link, var(--color-primary, currentColor));
}

.amv-control-button--icon {
    aspect-ratio: 1;
    min-width: var(--amv-control-min-height);
    padding: 0;
}

.amv-control-button__icon,
.amv-control-button__label {
    display: inline-flex;
    min-width: 0;
}

.amv-control-field {
    display: grid;
    gap: 0.35rem;
    min-width: 0;
}

.amv-control-field-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.65rem;
    min-width: 0;
}

.amv-control-field-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.amv-control-field-grid--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.amv-control-field-grid__full {
    grid-column: 1 / -1;
}

.amv-control-field__label {
    color: var(--color-text, #0f172a);
    font: 700 14px/1.2 Arial, sans-serif;
}

.amv-control-field__control,
.amv-control-field__input,
.amv-control-field__select,
.amv-control-field__textarea {
    width: 100%;
    min-height: var(--amv-control-min-height);
    border: 1px solid var(--amv-control-border);
    border-radius: var(--amv-control-radius);
    padding: var(--amv-control-padding-y) var(--amv-control-padding-x);
    background: var(--amv-control-bg);
    color: var(--amv-control-text);
    font: 400 14px/1.35 Arial, sans-serif;
}

.amv-control-field__textarea {
    min-height: 7rem;
    resize: vertical;
}

.amv-control-field__checkbox {
    width: 14px;
    height: 14px;
    accent-color: var(--color-primary, currentColor);
}

.amv-control-field__control:focus,
.amv-control-field__input:focus,
.amv-control-field__select:focus,
.amv-control-field__textarea:focus {
    border-color: var(--amv-control-focus);
    outline: 3px solid color-mix(in srgb, var(--amv-control-focus) 24%, transparent);
}

.amv-control-field__hint {
    color: var(--amv-control-muted);
    font: 400 13px/1.35 Arial, sans-serif;
}

.amv-control-field__error,
.amv-control-field.has-error .amv-control-field__label {
    color: var(--color-danger, #b42318);
}

.amv-control-field.has-error .amv-control-field__control,
.amv-control-field.has-error .amv-control-field__input,
.amv-control-field.has-error .amv-control-field__select,
.amv-control-field.has-error .amv-control-field__textarea {
    border-color: var(--color-danger, #b42318);
}

.amv-control-field--generated .amv-control-field__control,
.amv-control-field--generated .amv-control-field__input {
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
}

.amv-control-notice {
    border: 1px solid var(--amv-control-border);
    border-radius: var(--amv-control-radius);
    padding: 0.65rem 0.75rem;
    background: var(--amv-control-bg);
    color: var(--color-text, #0f172a);
    font: 400 14px/1.45 Arial, sans-serif;
}

.amv-control-notice--success {
    border-color: var(--color-success, #15803d);
}

.amv-control-notice--warning {
    border-color: var(--color-warning, #b45309);
}

.amv-control-notice--error {
    border-color: var(--color-danger, #b42318);
}

.amv-control-notice--info {
    border-color: var(--color-info, var(--amv-control-border));
}

.amv-control-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--amv-control-gap);
    min-width: 0;
}

.amv-control-list {
    display: grid;
    gap: var(--amv-control-gap);
    min-width: 0;
}

.amv-control-pagination {
    display: grid;
    justify-items: center;
    gap: 0.65rem;
}

.amv-control-pagination__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
}

.amv-control-pagination__jump {
    margin: 0;
}

.amv-control-pagination__jump input[type="text"] {
    box-sizing: border-box;
    width: 4.25rem;
    text-align: center;
}

.amv-control-empty {
    border: 1px dashed var(--amv-control-border);
    border-radius: var(--amv-control-radius);
    padding: 0.75rem;
    color: var(--amv-control-muted);
    font: 400 14px/1.45 Arial, sans-serif;
}

.amv-control-table-wrap {
    width: 100%;
    overflow-x: auto;
}

.amv-control-table {
    width: 100%;
    border-collapse: collapse;
}

.amv-control-table th,
.amv-control-table td {
    border-bottom: 1px solid var(--amv-control-border);
    padding: 0.5rem 0.6rem;
    text-align: left;
    vertical-align: top;
}

.amv-control-table th {
    color: var(--color-heading, #0f172a);
    font: 700 14px/1.25 Arial, sans-serif;
}

.amv-control-table td {
    color: var(--color-text, #0f172a);
    font: 400 14px/1.4 Arial, sans-serif;
}

.amv-control-pagination__link {
    display: inline-flex;
    min-height: var(--amv-control-min-height);
    align-items: center;
    border: 1px solid var(--amv-control-border);
    border-radius: var(--amv-control-radius);
    padding: var(--amv-control-padding-y) var(--amv-control-padding-x);
    color: var(--amv-link, var(--color-primary, currentColor));
    text-decoration: none;
}

.amv-control-pagination__status {
    color: var(--amv-control-muted);
    font: 400 14px/1.35 Arial, sans-serif;
}

.amv-control-modal[hidden] {
    display: none !important;
}

.amv-control-modal {
    position: fixed;
    inset: 0;
    overflow: auto;
    z-index: 12000;
}

.amv-control-modal__backdrop {
    position: absolute;
    inset: 0;
    display: flex;
    min-height: 100%;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background: color-mix(in srgb, var(--color-page-background, #0f172a) 72%, transparent);
}

.amv-control-modal__dialog {
    display: grid;
    width: 100%;
    max-width: min(92vw, 42rem);
    max-height: calc(100vh - 3rem);
    overflow: auto;
    border: 1px solid var(--amv-control-border);
    border-radius: var(--amv-control-radius);
    background: var(--amv-control-bg);
    color: var(--color-text, #0f172a);
    box-shadow: 0.65rem 0.8rem 1.2rem color-mix(in srgb, #000000 28%, transparent);
}

.amv-control-modal__header,
.amv-control-modal__body,
.amv-control-modal__footer {
    padding: 0.9rem;
}

.amv-control-modal__header,
.amv-control-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--amv-control-gap);
    border-bottom: 1px solid var(--amv-control-border);
}

.amv-control-modal__footer {
    justify-content: flex-end;
    border-top: 1px solid var(--amv-control-border);
    border-bottom: 0;
}

.amv-control-modal__close {
    display: inline-flex;
    width: 36px;
    min-width: 36px;
    min-height: 36px;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--amv-control-border);
    border-radius: var(--amv-control-radius);
    padding: 0 0 5px;
    background: var(--amv-control-bg);
    color: var(--amv-link, var(--color-primary, currentColor));
    font: 700 1.5rem/1 Arial, sans-serif;
    cursor: pointer;
}

.amv-control-modal__close:hover,
.amv-control-modal__close:focus-visible {
    background: color-mix(in srgb, var(--amv-link, var(--color-primary, currentColor)) 12%, transparent);
    outline: 2px solid transparent;
}

.amv-state {
    color: inherit;
    font: inherit;
    text-transform: none;
}

.amv-content-body::after {
    display: table;
    clear: both;
    content: "";
}

.amv-content-body img,
.amv-content-body figure {
    max-width: 100%;
    height: auto;
}

.amv-content-body .alignleft {
    float: left;
    margin: 0.25rem 1rem 1rem 0;
}

.amv-content-body .alignright {
    float: right;
    margin: 0.25rem 0 1rem 1rem;
}

.amv-content-body .aligncenter {
    display: block;
    margin: 1rem auto;
    text-align: center;
}

.amv-content-body figure.alignleft,
.amv-content-body figure.alignright {
    max-width: min(50%, 420px);
}

.amv-content-body figcaption {
    margin-top: 0.35rem;
    font-size: 0.9em;
    opacity: 0.75;
    text-align: center;
}

@media (max-width: 720px) {
    .amv-control-field-grid--two,
    .amv-control-field-grid--three {
        grid-template-columns: 1fr;
    }

    .amv-control-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .amv-control-toolbar > * {
        width: 100%;
    }

    .amv-content-body .alignleft,
    .amv-content-body .alignright {
        display: block;
        float: none;
        max-width: 100%;
        margin: 1rem auto;
    }
}
