:root {
    /* Colors */
    --color-white: #f4f4f5;
    --color-black: #231f20;
    --color-gray: #c2c2bf;
    --color-dark: #2c3337;
    --color-blue: #249cd1;
    --color-yellow: #eec21b;
    --color-blue-light: #4dc3f7;
    --color-blue-dark: #1b7ca8;
    --color-yellow-light: #f7dc6f;
    --color-yellow-dark: #cba715;
    --color-border: rgba(0, 0, 0, 0.1);
    --color-shadow: rgba(0, 0, 0, 0.15);

    /* Font Sizes */
    --font-s-small: 0.7rem;
    --font-s-medium: 0.9rem;
    --font-s-normal: 1.1rem;
    --font-s-large: 1.4rem;
    --font-s-gigantte: 1.8rem;

    /* Fonts */
    --fonts-nav: font-nav;
    --fonts-italic: font-italic;
    --fonts-text: font-text;
    --fonts-title: font-title;
    --fonts-subtitle: font-subtitle;
    --fonts-navigation: font-navigation;

    --mx-width: 1366px;

    /* Letter Spacing */
    --letter-spacing-shore: 0.73px;
    --letter-spacing-medium: 1.1px;
    --letter-spacing-large: 1.5px;

    /* Spacing */
    --space-s: 1rem;
    --space-m: 1.5rem;
    --space-l: 2rem;

    /* Border Radius */
    --radius-small: 5px;
    --radius-medium: 10px;
    --radius-large: 20px;

    /* Shadows */
    --shadow-light: 0 2px 4px rgba(0, 0, 0, 0.1);
    --shadow-medium: 0 4px 8px rgba(0, 0, 0, 0.15);
    --box-shadow: rgba(33, 35, 38, 0.1) 0px 10px 10px -10px;

    /* Transitions */
    --transition-normal: 0.3s ease-in-out;

    /* Line Height */
    --line-height-normal: 1.5;

    /* Z-index */
    --z-header: 1000;
    --z-modal: 2000;
}

body.body_general {
    background-color: var(--color-white);
    font-family: 'font-text', sans-serif;
    margin: 0;
}

/* Center the login section vertically */
.sicgbor_login {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    min-height: calc(100vh - 200px); /* adjust for header/footer */
    padding: var(--space-m);
}

/* Container */
.sicgbor_login_container {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 400px;
    background-color: var(--color-white);
    padding: 40px 25px;
    border-radius: var(--radius-medium);
    box-shadow: 0 10px 25px rgba(0,0,0,0.15);
    gap: var(--space-m);
}

/* Logo */
.sicgbor_login_imgs {
    width: 120px;
    height: auto;
}

/* Titles */
.sicgbor_login_title {
    font-size: var(--font-s-gigantte);
    color: var(--color-dark);
    font-family: var(--fonts-title);
    margin: 0;
    text-align: center;
}

.sicgbor_login_subtitle {
    font-family: var(--fonts-subtitle);
    color: var(--color-gray);
    letter-spacing: var(--letter-spacing-shore);
    font-size: var(--font-s-medium);
    text-align: center;
}

/* Form */
.sicgbor_login_form {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

/* Input wrapper */
.input_icon_wrapper {
    position: relative;
    width: 100%;
}

.input_icon_wrapper i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gray);
    font-size: 1rem;
    pointer-events: none;
}

.input_icon_wrapper input {
    width: 100%;
    padding: 12px 15px 12px 40px; /* space for icon */
    border-radius: var(--radius-medium);
    border: 1px solid var(--color-border);
    font-size: 1rem;
    box-sizing: border-box;
}

/* Submit button */
.sicgbor_logins_login {
    width: 100%;
    padding: 12px;
    font-family: var(--fonts-subtitle);
    border-radius: var(--radius-medium);
    letter-spacing: var(--letter-spacing-shore);
    border: none;
    background-color: var(--color-blue);
    color: var(--color-white);
    font-size: 1rem;
    cursor: pointer;
    transition: var(--transition-normal);
}

.sicgbor_logins_login:hover {
    background-color: var(--color-blue-dark);
}

/* Links */
.sicgbor_login_link {
    font-size: 0.9rem;
    text-align: center;
}

.sicgbor_login_forgots {
    color: var(--color-blue);
    letter-spacing: var(--letter-spacing-shore);
    font-family: var(--fonts-subtitle);
    text-decoration: none;
}

.sicgbor_login_forgots:hover {
    text-decoration: underline;
}

/* Error & Success messages */
.sicgbor_error {
    color: #d93025;
    font-size: var(--font-s-normal);
    text-align: center;
    margin-bottom: var(--space-s);
}

.sicgbor_success {
    color: #188038;
    font-size: var(--font-s-normal);
    text-align: center;
    margin-bottom: var(--space-s);
}

/* Responsive */
@media screen and (max-width: 480px) {
    .sicgbor_login_container {
        padding: 30px 15px;
    }
}

/* Page Body */
body.body_general {
    background-color: var(--color-white);
    font-family: var(--fonts-text), sans-serif; /* Default text font */
    margin: 0;
}


/* Form input placeholders */
.input_icon_wrapper input::placeholder {
    font-family: var(--fonts-text); /* Use text font for placeholders */
    color: var(--color-gray);
}

/* Buttons */
.sicgbor_logins_login {
    font-family: var(--fonts-subtitle); /* Use subtitle font */
}

/* Links */
.sicgbor_login_forgots {
    font-family: var(--fonts-subtitle); /* Use subtitle font */
}

/* Messages */
.sicgbor_error, .sicgbor_success {
    font-family: var(--fonts-text); /* Use text font */
}


/* Input wrapper for icon */
.input_icon_wrapper {
    position: relative;
    width: 100%;
}

.input_icon_wrapper i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gray);
    font-size: 1rem;
    pointer-events: none;
}

/* Input field spacing for icon */
.input_icon_wrapper input {
    width: 100%;
    padding: 12px 15px 12px 40px; /* space for icon */
    border-radius: var(--radius-medium);
    border: 1px solid var(--color-border);
    font-size: 1rem;
    font-family: var(--fonts-text);
    box-sizing: border-box;
}

/* Submit button */
.sicgbor_logins_login {
    width: 100%;
    padding: 12px;
    font-family: var(--fonts-subtitle);
    border-radius: var(--radius-medium);
    letter-spacing: var(--letter-spacing-shore);
    border: none;
    background-color: var(--color-blue);
    color: var(--color-white);
    font-size: 1rem;
    cursor: pointer;
    transition: var(--transition-normal);
}

.sicgbor_logins_login:hover {
    background-color: var(--color-blue-dark);
}
