/* CSS Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    color: var(--color-dark);
    font-family: 'Geomanist', Arial, sans-serif;
}

/* Font-face definitions */
@font-face {
    font-family: 'Geomanist';
    src: url('/assets/fonts/geomanist-bold-webfont.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
}
@font-face {
    font-family: 'Geomanist';
    src: url('/assets/fonts/geomanist-medium-webfont.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
}
@font-face {
    font-family: 'Geomanist';
    src: url('/assets/fonts/geomanist-regular-webfont.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
}

/* Font variables */
:root {
    --h1: clamp(2.625rem, 1.6094rem + 3.25vw, 3.4375rem); /* 55px to 42px */
    --p: clamp(1.0625rem, 0.9844rem + 0.25vw, 1.125rem); /* 18px to 17px */
    --p-xs: 0.813rem; /* 13px */
    --p-ss: 0.875rem; /* 14px */
    --p-s: 1rem; /* 16px */
    --p-m: 1.063rem; /* 17px */
}
/* Spacing variables */
:root {
    --space-l: clamp(5.46875rem, 2.5391rem + 9.375vw, 7.8125rem); /* 125px to 87.5px */
    --space-m: clamp(4.375rem, 2.0313rem + 7.5vw, 6.25rem); /* 100px to 70px */
    --space-s: clamp(3.28125rem, 1.5234rem + 5.625vw, 4.6875rem); /* 75px to 52.5px */
    --space-xs: clamp(2.1875rem, 1.0156rem + 3.75vw, 3.125rem); /* 50px to 35px */
    --space-horizontal: clamp(1.25rem, -3.0469rem + 13.75vw, 4.6875rem); /* 75px to 20px */
}
/* Other variables */
:root {
    --border-radius-l: 10px;
    --border-radius-m: 8px;
}
/* Color variables */
:root {
    --color-white: #ffffff;
    --color-netrual-300: #E7E7E7;
    --color-dark: #333333;
    --color-dark-300: #777777;
    --color-alert: #AF1212;
}

h1 {
    font-size: var(--h1);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.025em;
}
p, span {
    font-size: var(--p);
    font-weight: 400;
    line-height: 1.6;
}

body {
    background-color: var(--color-netrual-300);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-l) var(--space-horizontal);
}

.header {
    text-align: left;
    margin-bottom: 25px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 15px;
}

.header:after {
    content: "v1.0.3";
    display: inline-flex;
    font-size: var(--p-ss);
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: 0;
    background-color: var(--color-white);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.08);
    border-radius: var(--border-radius-m);
    padding: 7px 20px 5px 20px;
}

.description {
    margin-bottom: var(--space-xs);
    text-align: left;
    width: 100%;
    font-weight: 400;
}

.container {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 750px;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeOut {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-20px);
    }
}

.group {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: space-between;
    width: 100%;
    margin-bottom: var(--space-xs);
    border-radius: var(--border-radius-l);
    overflow: hidden;
    background-color: var(--color-white);
    position: relative;
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.08);
    animation: fadeIn 0.15s ease-in-out;
}

.group.removing {
    animation: fadeOut 0.15s ease-in-out;
}

.group__content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: calc(100% - 80px);
    max-width: 530px;
}

.group__header {
    display: flex;
    flex-direction: column;
    width: 100%;
    border-radius: 0 0 var(--border-radius-m) 0;
    background-color: var(--color-dark);
    padding: 13px 34px 11px 34px;
}

.group__layer-label {
    color: var(--color-white);
    font-weight: 500;
    line-height: 1.2;
    font-size: var(--p-s);
}

.group__body-wrapper {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 40px 0 40px 30px;
}

.group__body {
    display: flex;
    flex-direction: column;
}

.group__field {
    margin-bottom: 40px;
}

.group__label {
    display: flex;
    margin-bottom: 8px;
    font-weight: 500;
    font-size: var(--p-m);
    line-height: 1.2;
    padding-left: 4px;
}

::placeholder {
    color: var(--color-dark-300);
    opacity: 1; /* Firefox */
}

.group__input {
    width: 100%;
    padding: 13px 15px;
    margin-bottom: 10px;
    border: 1px solid #DCDCDC;
    box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.10);
    font-size: var(--p-s);
    line-height: 1.2;
    border-radius: var(--border-radius-m);
}

.group__input[type=file] {
    cursor: pointer;
    color: var(--color-dark-300);
    padding: 0 15px 0 0;
}

.group__input[type=file]::file-selector-button {
    background-color: var(--color-netrual-300);
    font-family: 'Geomanist', Arial, sans-serif;
    color: var(--color-dark);
    line-height: 1.2;
    font-size: var(--p-s);
    border: 0px;
    padding: 13px 20px;
    margin-right: 20px;
    cursor: pointer;
}

.group__instructions {
    font-size: var(--p-xs);
    color: var(--color-dark-300);
    line-height: 1.2;
    padding-left: 4px;
}

.group__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.group__button {
    display: flex;
    align-items: center;
    padding: 6px 13px 6px 8px;
    border: none;
    border-radius: var(--border-radius-m);
    background-color: var(--color-dark);
    color: var(--color-white);
    cursor: pointer;
    transition: background-color 0.3s;
    text-align: center;
    font-size: var(--p-ss);
    font-weight: 500;
    line-height: 1.6;
}

.group__button svg {
    margin-right: 3px;
}

.group__button--remove {
    background-color: var(--color-alert);
}

.group__button--remove[disabled] {
    opacity: 0.3;
    filter: grayscale(100%);
    cursor: not-allowed;
}

.group__button--remove:hover {
    background-color: var(--color-alert);
}

.group__button--add {
    background-color: var(--color-dark);
}

.group__button--add:hover {
    background-color: var(--color-dark);
}

.group__drag-handle {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
    cursor: grab;
    background-color: var(--color-dark);
}

.form {
    margin-bottom: 20px;
}

.form--disabled {
    opacity: 0.5;
    filter: grayscale(100%);
    pointer-events: none;
}

.button--generate {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 10px 13px;
    border: none;
    border-radius: var(--border-radius-m);
    background-color: var(--color-dark);
    color: var(--color-white);
    cursor: pointer;
    transition: background-color 0.3s;
    text-align: center;
    font-size: var(--p);
    font-weight: 500;
    line-height: 1.6;
}

.button--generate svg {
    margin-left: 4px;
}

.generate-help {
    margin-bottom: 25px;
    font-size: var(--p-xs);
    color: var(--color-dark-300);
    line-height: 1.2;
    text-align: center;
}

.progress__text {
    margin-top: 15px;
    font-weight: 500;
    font-size: var(--p-s);
}

.progress {
    display: none;
    margin-top: 30px;
}

.progress__background {
    width: 100%;
    height: 20px;
    background-color: var(--color-white);
    border-radius: var(--border-radius-m);
    overflow: hidden;
}

.progress__bar {
    width: 0;
    height: 100%;
    background-color: var(--color-alert);
    transition: width 0.3s;
}