/* ==========================================================================
   Forms & Controls
   ========================================================================== */

:root {
    --control-height            : 2.5rem;
    --control-padding-x         : 0.75rem;
    --control-font-size         : 0.9375rem;
    --control-border-width      : 1px;
    --control-border-color      : #c8cdd4;
    --control-bg                : #ffffff;
    --control-color             : #1a1a1a;
    --control-placeholder-color : #9aa0a8;
    --control-focus-shadow      : 0 0 0 3px rgb(59 130 246 / 0.2);
    --control-disabled-bg       : #f3f4f6;
    --control-disabled-color    : #9aa0a8;
    --control-border-radius     : 0px;
}

.rounded {
    --control-border-radius : var(--border-radius, 6px);
}

/* ==========================================================================
   Base
   ========================================================================== */

fieldset {
    legend {
        padding : 0 0.5rem;
    }
}

html.rounded {
    fieldset {
        border-radius : 8px;
    }
}

input,
select,
textarea,
button,
.btn {
    box-sizing         : border-box;
    font-family        : inherit;
    font-size          : var(--control-font-size);
    color              : var(--control-color);
    border             : var(--control-border-width) solid var(--control-border-color);
    border-radius      : var(--control-border-radius);
    background-color   : var(--control-bg);
    transition         : border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
    outline            : none;
    appearance         : none;
    -webkit-appearance : none;
}

input:focus,
select:focus,
textarea:focus,
button:focus-visible,
.btn:focus-visible {
    border-color : var(--color-primary);
    box-shadow   : var(--control-focus-shadow);
}

input:disabled,
select:disabled,
textarea:disabled,
button:disabled,
.btn:disabled {
    background-color : var(--control-disabled-bg);
    color            : var(--control-disabled-color);
    cursor           : not-allowed;
    opacity          : 1;
}

/* ==========================================================================
   Inline controls – gleiche Höhe für sauberes Alignment
   ========================================================================== */

input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]),
select,
button[type="button"],
button[type="reset"],
button[type="submit"],
.btn {
    height         : var(--control-height);
    padding        : 0 var(--control-padding-x);
    line-height    : calc(var(--control-height) - var(--control-border-width) * 2);
    display        : inline-flex;
    align-items    : center;
    vertical-align : middle;
    white-space    : nowrap;
}

/* ==========================================================================
   Text inputs
   ========================================================================== */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="url"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
input[type="month"],
input[type="week"],
input[type="time"] {
    width : 100%;
}

input::placeholder {
    color   : var(--control-placeholder-color);
    opacity : 1;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance : none;
    margin             : 0;
}

input[type="number"] {
    -moz-appearance : textfield;
}

input[type="search"]::-webkit-search-cancel-button {
    -webkit-appearance : none;
}

/* ==========================================================================
   Select
   ========================================================================== */

select {
    width               : 100%;
    padding-right       : 2.25rem;
    background-image    : url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239aa0a8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat   : no-repeat;
    background-position : right 0.75rem center;
    cursor              : pointer;
}

select:disabled {
    cursor : not-allowed;
}

select[multiple] {
    height           : auto;
    padding          : 0.5rem var(--control-padding-x);
    background-image : none;
}

/* ==========================================================================
   Textarea
   ========================================================================== */

textarea {
    width       : 100%;
    height      : auto;
    min-height  : 6rem;
    padding     : 0.625rem var(--control-padding-x);
    line-height : 1.5;
    resize      : vertical;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.btn {
    background-color : #ffffff;
    cursor           : pointer;
    font-weight      : 500;
    gap              : 0.4em;
    justify-content  : center;
    user-select      : none;
    color            : var(--control-color);
    border-color     : var(--control-border-color);
    
    &:hover:not(:disabled) {
        background-color : #f3f4f6;
    }
    
    &:disabled {
        cursor : not-allowed;
    }
    
    &:focus-visible {
        outline        : 2px solid var(--color-primary);
        outline-offset : 2px;
    }
}

.btn-primary {
    background-color : var(--color-primary);
    color            : #ffffff;
    border-color     : #00000022;
    
    &:hover:not(:disabled) {
        background-color : var(--color-primary-brighter);
    }
}

.btn.btn-secondary {
    background-color : var(--color-secondary);
    color            : var(--color-secondary-contrast);
    border-color     : var(--color-secondary-darker);
    
    &:hover:not(:disabled) {
        background-color : var(--color-secondary-darker);
    }
}

.btn-ghost {
    background-color : transparent;
    border-color     : transparent;
    color            : var(--control-color);
}

.btn-ghost:hover:not(:disabled) {
    background-color : #f3f4f6;
    border-color     : #dddddd;
}

/* ==========================================================================
   Checkbox & Radio
   ========================================================================== */

input[type="checkbox"],
input[type="radio"] {
    width          : 1rem;
    height         : 1rem;
    padding        : 0;
    flex-shrink    : 0;
    cursor         : pointer;
    vertical-align : middle;
}

input[type="radio"] {
    border-radius : 50%;
}

input[type="checkbox"] {
    border-radius : calc(var(--control-border-radius) * 0.5);
}

input[type="checkbox"]:checked,
input[type="radio"]:checked {
    background-color : var(--color-primary);
    border-color     : #00000022;
}

input[type="checkbox"]:checked {
    background-image    : url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M2 6l3 3 5-5'/%3E%3C/svg%3E");
    background-repeat   : no-repeat;
    background-position : center;
    background-size     : 0.75rem;
}

input[type="radio"]:checked {
    background-image    : url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Ccircle cx='6' cy='6' r='2.5' fill='%23fff'/%3E%3C/svg%3E");
    background-repeat   : no-repeat;
    background-position : center;
}

/* ==========================================================================
   File Upload
   ========================================================================== */

input[type="file"] {
    height      : auto;
    padding     : 0;
    border      : none;
    background  : none;
    font-size   : 0.875rem;
    cursor      : pointer;
    line-height : normal;
}

input[type="file"]::file-selector-button {
    height             : var(--control-height);
    padding            : 0 var(--control-padding-x);
    margin-right       : 0.75rem;
    font-size          : var(--control-font-size);
    font-family        : inherit;
    font-weight        : 500;
    color              : var(--control-color);
    background-color   : #f3f4f6;
    border             : var(--control-border-width) solid var(--control-border-color);
    border-radius      : var(--control-border-radius);
    cursor             : pointer;
    transition         : background-color 0.15s ease;
    appearance         : none;
    -webkit-appearance : none;
}

input[type="file"]::file-selector-button:hover {
    background-color : #e5e7eb;
}

/* ==========================================================================
   Range
   ========================================================================== */

input[type="range"] {
    width      : 100%;
    height     : 1.25rem;
    padding    : 0;
    border     : none;
    background : transparent;
    cursor     : pointer;
}

input[type="range"]::-webkit-slider-runnable-track {
    height           : 0.375rem;
    background-color : #e5e7eb;
    border-radius    : var(--control-border-radius);
}

input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance : none;
    width              : 1rem;
    height             : 1rem;
    margin-top         : -0.3125rem;
    background-color   : var(--color-primary);
    border             : 2px solid #ffffff;
    border-radius      : 50%;
    box-shadow         : 0 1px 3px rgb(0 0 0 / 0.2);
}

input[type="range"]::-moz-range-track {
    height           : 0.375rem;
    background-color : #e5e7eb;
    border-radius    : var(--control-border-radius);
}

input[type="range"]::-moz-range-thumb {
    width            : 1rem;
    height           : 1rem;
    background-color : var(--color-primary);
    border           : 2px solid #ffffff;
    border-radius    : 50%;
    box-shadow       : 0 1px 3px rgb(0 0 0 / 0.2);
}

/* ==========================================================================
   Layout helpers
   ========================================================================== */

.form-group {
    display        : flex;
    flex-direction : column;
    gap            : 0.375rem;
}

.form-label {
    font-size   : 0.875rem;
    font-weight : 500;
    color       : var(--control-color);
}

.form-hint {
    font-size : 0.8125rem;
    color     : var(--control-placeholder-color);
}

.form-error {
    font-size : 0.8125rem;
    color     : #ef4444;
}

.is-invalid,
input:user-invalid,
select:user-invalid,
textarea:user-invalid {
    border-color : #ef4444;
}

.is-invalid:focus,
input:user-invalid:focus,
select:user-invalid:focus,
textarea:user-invalid:focus {
    border-color : #ef4444;
    box-shadow   : 0 0 0 3px rgb(239 68 68 / 0.2);
}

/* Input + Button nebeneinander */
.form-row {
    display     : flex;
    align-items : center;
    gap         : 0.5rem;
}

.form-row input,
.form-row select {
    flex  : 1 1 auto;
    width : auto;
}

/* ==========================================================================
   Button Group & Input Addon
   ========================================================================== */

/* ==========================================================================
   Button Group – mehrere Buttons als ein visuelles Control
   ========================================================================== */

.btn-group {
    display        : inline-flex;
    vertical-align : middle;
}

.btn-group > button,
.btn-group > .btn {
    border-radius : 0;
    margin-left   : calc(var(--control-border-width) * -1); /* Doppelte Border vermeiden */
    position      : relative;
}

.btn-group > button:first-child,
.btn-group > .btn:first-child {
    border-radius : var(--control-border-radius) 0 0 var(--control-border-radius);
    margin-left   : 0;
}

.btn-group > button:last-child,
.btn-group > .btn:last-child {
    border-radius : 0 var(--control-border-radius) var(--control-border-radius) 0;
}

/* Nur ein Kind: normaler Button */
.btn-group > button:only-child,
.btn-group > .btn:only-child {
    border-radius : var(--control-border-radius);
    margin-left   : 0;
}

/* Fokus/Hover nach vorne bringen damit Border nicht abgeschnitten wird */
.btn-group > button:hover,
.btn-group > .btn:hover,
.btn-group > button:focus-visible,
.btn-group > .btn:focus-visible {
    z-index : 1;
}

/* Active/selected Item in der Gruppe */
.btn-group > button.is-active,
.btn-group > .btn.is-active {
    z-index          : 1;
    background-color : var(--color-primary);
    border-color     : #00000022;
    color            : #ffffff;
}

/* ==========================================================================
   Input Addon – Input mit angehängtem Button oder Label
   ========================================================================== */

.input-addon {
    display        : inline-flex;
    vertical-align : middle;
    width          : 100%;
    align-items    : center;
    height         : var(--control-height);
}

.input-addon > * {
    flex          : 1 1 auto;
    width         : auto;
    min-width     : 0; /* Verhindert overflow in flex */
    border-radius : 0;
    margin-left   : calc(var(--control-border-width) * -1);
    position      : relative;
}

.input-addon input:focus,
.input-addon select:focus {
    z-index : 1;
}

/* Erstes & letztes Kind bekommt die äußeren Radii */
.input-addon > *:first-child {
    border-radius : var(--control-border-radius) 0 0 var(--control-border-radius);
    margin-left   : 0;
}

.input-addon > *:last-child {
    border-radius : 0 var(--control-border-radius) var(--control-border-radius) 0;
}

/* Nur ein Kind */
.input-addon > *:only-child {
    border-radius : var(--control-border-radius);
}

/* Text-Label (zB "https://" oder "@" oder "kg") */
.addon-label {
    display          : inline-flex;
    align-items      : center;
    padding          : 0 var(--control-padding-x);
    height           : var(--control-height);
    font-size        : var(--control-font-size);
    color            : var(--control-placeholder-color);
    background-color : #f3f4f6;
    border           : var(--control-border-width) solid var(--control-border-color);
    white-space      : nowrap;
    flex-shrink      : 0;
    margin-left      : calc(var(--control-border-width) * -1);
}

/* Button im Addon braucht keinen extra border-radius, kommt vom :first/:last-child */
.input-addon > button,
.input-addon > .btn {
    flex-shrink : 0;
}

/* Legacy: Fehler im Formular */
form {
    .field-error {
        display   : block;
        color     : var(--color-error);
        font-size : 13px;
        padding   : 0.1rem 0.2rem;
        margin    : 0.2rem 0;
    }
}
