/* VINARICE.NET - Roundcube Login - FINÁLNÍ FIX */

/* === POZADÍ === */
body.task-login {
    background: #FFCF00 !important;
    min-height: 100vh !important;
    padding: 10px 0 !important;
    margin: 0 !important;
}

/* === LAYOUT KONTEJNER === */
body.task-login #layout {
    display: block !important;
    width: 320px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    flex: none !important;
}

/* === LOGO === */
body.task-login #logo-container {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    margin-top: calc(10vh - 10px) !important;
    margin-bottom: 1px !important;
    padding: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    z-index: 10 !important;
}

body.task-login #logo-container img {
    display: block !important;
    max-height: 130px !important;
    width: auto !important;
    margin: 0 auto !important;
    position: relative !important;
    left: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Override Roundcube default that pushes logo down */
body.task-login #logo {
    position: static !important;
    top: 0 !important;
    transform: none !important;
}

/* === PANEL - OVERRIDE FLEX === */
body.task-login #layout-content {
    display: block !important;
    flex: none !important;
    flex-direction: initial !important;
    background: #fff5cc !important;
    backdrop-filter: blur(25px) !important;
    border-radius: 12px !important;
    box-shadow: 0 0 10px rgba(77, 77, 77, 0.5) !important;
    padding: 12px !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
}

/* === NADPIS === */
body.task-login #login-heading {
    font-size: calc(1.25rem + 2px) !important;
    font-weight: 600 !important;
    color: #000000 !important;
    text-align: center !important;
    margin: 0 0 24px 0 !important;
    padding: 0 !important;
    line-height: 1.4 !important;
    white-space: pre-line !important;
    letter-spacing: 0.3px !important;
}

/* === FORMULÁŘ - OVERRIDE PROPFORM === */
body.task-login form.propform,
body.task-login #login-form {
    display: block !important;
    margin: 0 auto !important;
    padding: 0 !important;
    height: auto !important;
    position: static !important;
    top: 0 !important;
    width: 100% !important;
    max-width: 320px !important;
}

/* === SKRÝT INPUT-GROUP IKONY === */
body.task-login .input-group-text,
body.task-login .input-group-addon,
body.task-login .input-group-prepend {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* === SKRÝT HIDDEN INPUTS === */
body.task-login input[type="hidden"],
body.task-login input[type="hidden"].form-control {
    display: none !important;
    position: absolute !important;
    left: -10000px !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    visibility: hidden !important;
}

/* === TABLE - FLOATING LABELS === */
body.task-login #login-form table {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

body.task-login #login-form tbody {
    display: block !important;
}

body.task-login #login-form tr {
    display: block !important;
    position: relative !important;
    margin-bottom: 12px !important;
}

body.task-login #login-form tr:last-of-type {
    margin-bottom: 0 !important;
}

body.task-login #login-form td {
    display: block !important;
    padding: 0 !important;
}

body.task-login #login-form td.title {
    position: absolute !important;
    top: -10px !important;
    left: 12px !important;
    z-index: 2 !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
}

/* === LABELY - FLOATING STYLE === */
body.task-login #login-form td.title label {
    font-weight: 500 !important;
    color: #6b6b6b !important;
    font-size: 13px !important;
    display: inline-block !important;
    line-height: 1.5 !important;
    background-color: #ffffff !important;
    padding: 0 4px !important;
    border-radius: 4px 4px 0 0 !important;
    margin: 0 !important;
}

/* === INPUTY === */
body.task-login #login-form input[type="text"],
body.task-login #login-form input[type="password"] {
    width: 100% !important;
    height: 36px !important;
    padding: 0 12px !important;
    border: 2px solid #ededed !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    background: #ffffff !important;
    color: #6b6b6b !important;
    box-sizing: border-box !important;
    position: relative !important;
    z-index: 1 !important;
}

body.task-login #login-form input:focus {
    border-color: #000000 !important;
    outline: none !important;
    z-index: 1 !important;
}

/* === FORMBUTTONS === */
body.task-login .formbuttons {
    margin: 8px 0 0 0 !important;
    padding: 0 !important;
}

body.task-login #login-form button {
    background: #A01800 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    width: 100% !important;
    height: 36px !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
}

body.task-login #login-form button:hover {
    background: #b34632 !important;
}

/* === SSO BUTTON === */
body.task-login .sso-button {
    background: #A01800 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 0 !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    display: block !important;
    text-align: center !important;
    margin: 0 !important;
    width: 100% !important;
    height: 36px !important;
    line-height: 36px !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
}

body.task-login .sso-button:hover {
    background: #b34632 !important;
    text-decoration: none !important;
}

/* === LOGIN FOOTER === */
body.task-login #login-footer {
    background: transparent !important;
    background-color: transparent !important;
}

body.task-login #login-footer > div {
    padding: 0 !important;
}

/* === FOOTER === */
body.task-login #login-footer {
    text-align: center !important;
    font-size: 12px !important;
    color: #666 !important;
    margin-top: 8px !important;
    padding-top: 8px !important;
    border-top: 1px solid rgba(229, 184, 0, 0.2) !important;
}

/* === SCREEN READER === */
body.task-login .voice {
    position: absolute !important;
    left: -10000px !important;
}

/* === MOBILNÍ === */
@media (max-width: 480px) {
    body.task-login #layout {
        width: 100vw !important;
        padding: 0 !important;
    }

    body.task-login #logo-container {
        margin: 5px 0 !important;
    }

    body.task-login #logo-container img {
        max-height: 80px !important;
    }

    body.task-login #layout-content {
        width: 100vw !important;
        border-radius: 0 !important;
    }
}
