/* Variables. */
:root {
    --im-cw-font-size-text: 16px;
    --im-cw-font-size-input: 15px;
    --im-cw-font-weight-normal: 400;
    --im-cw-font-weight-bold: 700;
    --im-cw-color-text: #1d1d1d;
    --im-cw-color-primary: #000000;
    --im-cw-color-background: #ffffff;
    --im-cw-color-border: #e0e0e0;
    --im-cw-color-info: #33b5e5;
    --im-cw-color-success: #4cc07f;
    --im-cw-color-error: #ed4337;
    --im-cw-border-radius: 0;
}


/* Messages. */
.im-cw-message {
    display: block;
    margin-bottom: 24px;
    padding: 16px 20px;
    background: var(--im-cw-color-background);
    border: 1px solid var(--im-cw-color-border);
    border-radius: var(--im-cw-border-radius);
    color: var(--im-cw-color-text);
    font-size: var(--im-cw-font-size-text);
    font-weight: var(--im-cw-font-weight-normal);
    line-height: 1.6;
}

.im-cw-message.-info {
    border-color: var(--im-cw-color-info);
    color: var(--im-cw-color-info);
}

.im-cw-message.-success {
    border-color: var(--im-cw-color-success);
    color: var(--im-cw-color-success);
}

.im-cw-message.-error {
    border-color: var(--im-cw-color-error);
    color: var(--im-cw-color-error);
}


/* Rows & Cols. */
.im-cw-row {
    display: flex;
    margin: 0 -16px;
    flex-wrap: wrap;
}

.im-cw-col-half {
    width: 100%;
    padding: 0 16px;
}

@media (min-width: 768px) {
    .im-cw-col-half {
        width: 50%;
    }
}


/* Forms. */
.im-cw-form {
    width: 100%;
    max-width: 640px;
    margin: 0 auto;
}

.im-cw-form-group {
    margin-bottom: 24px;
}

.im-cw-form-label {
    display: block;
    margin-bottom: 8px;
    color: var(--im-cw-color-text);
    font-size: var(--im-cw-font-size-text);
    font-weight: var(--im-cw-font-weight-normal);
}

.im-cw-form-label.-required::after {
    content: "*";
    margin-left: 2px;
    color: var(--im-cw-color-error);
}

.im-cw-form-control {
    display: block;
    width: 100%;
    min-width: 0;
    padding: 12px 16px;
    background: var(--im-cw-color-background);
    border: 1px solid var(--im-cw-color-border);
    border-radius: var(--im-cw-border-radius);
    color: var(--im-cw-color-text);
    font-size: var(--im-cw-font-size-input);
    font-weight: var(--im-cw-font-weight-normal);
    line-height: 1.6;
    transition: border-color 0.2s ease;
}

.im-cw-form-control:focus {
    border-color: var(--im-cw-color-primary);
    outline: none;
}


/* Buttons. */
.im-cw-button {
    display: inline-block;
    padding: 12px 24px;
    background: var(--im-cw-color-primary);
    border: none;
    border-radius: var(--im-cw-border-radius);
    color: var(--im-cw-color-background);
    font-size: var(--im-cw-font-size-text);
    font-weight: var(--im-cw-font-weight-bold);
    line-height: 1.6;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.im-cw-button:hover, .im-cw-button:active, .im-cw-button:focus {
    outline: none;
    box-shadow: none;
}
