@import url('https://fonts.googleapis.com/css2?family=BBH+Sans+Hegarty&display=swap');
:root {

  --color-primary: #007bff;
  --color-secondary: #6c757d;
  --color-accent: orangered;
  --input-color:white;
  


  --color-background: #ffffff;
  --color-bg2:lightblue;
  --color-surface: #f5f5f5;
  --color-text: #212121;
  --color-text-light: #ffffff;


  --font-family-base: 'BBH Sans Hegarty', sans-serif;
  --font-size-base: 16px;
  --font-weight-normal: 400;
  --font-weight-bold: 600;


  --border-radius: 8px;
  --spacing: 1rem;


  --transition-speed: 0.3s;
}

*{
    margin:0;
    padding:0;
}
html{
    font-family :'sans-serif', 'Segoe UI';
    font-size: 15pt;
    color:var(--text-color);
    text-align:center;
}
body{
    min-height: 100vh;
    /* background-image: url(bg-blue.jpg); */
    background-size: cover;
    background-position: right;
    overflow:hidden;
}

.wrapper{
    box-sizing: border-box;
    background-color: var(--base-color);
    height:100vh;
    width: max(40%, 600px);
    padding : 10px;
    border-radius: 0 20px 20px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

h1{
    font-size: 3rem;
    font-weight: 900;
    text-transform: uppercase;
}

form{
    width: min(400px, 100%);
    margin-top: 20px;
    margin-bottom: 50px;
    display:flex;
    flex-direction: column;
    align-items: center;
    gap:10px;
}

form > div {
    width: 100%;
    display: flex;
    justify-content: center;
}

form label {
    flex-shrink: 0;
    height:50px;
    width:50px;
    background-color:var(--color-accent);
    color: var(--base-color);
    border-radius: 10px 0 0 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.5rem;
    font-weight: 500;
}

form input{
    box-sizing: border-box;
    flex-grow: 1;
    min-width: 0;
    height: 50px;
    padding:1em;
    font:inherit;
    border-radius: 0 10px 10px 0;
    border:2px solid var(--input-color);
    border-left: none;
    background-color: var(--input-color);
    transition:150ms ease;
}

form input:hover{
    border-color: var(--color-accent);
}
form-input:focus{
    outline:none;
    border-color: var(--text-color);
}
div:has(input:focus) > label{
    background-color: var(--color-bg2);
    opacity: 1;
}
form button{
    margin-top: 10px;
    border:none;
    border-radius:1000px;
    padding:.85em 4em;
    background-color: var(--color-accent);
    color:black;
    font:inherit;
    font-weight: 600;
    text-transform: uppercase;
    cursor:pointer;
}
form button:hover{
    background-color: var(--color-bg2);
}
form button:focus{
    outline:none;
    background-color: var(--color-bg2);
}
a{
    text-decoration: none;
    color:var(--color-accent);

}
a:hover{
    text-decoration: underline;
}
@media(max-width:1100px){
    .wrapper{
        width: min(600px, 100%);
        border-radius: 0;
    }
}

form div.incorrect label{
    background-color: red;
}
form div.incorrect input{
    background-color: red;
}










