/* login.css - styling for portal login page */
html, body {
    height: 100%;
    margin: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}
body {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}
.login-card {
    background: #fff;
    border-radius: 0.75rem;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
    max-width: 400px;
    width: 100%;
    padding: 2rem;
}
.login-card h2 {
    margin-bottom: 1.5rem;
    text-align: center;
    font-weight: 700;
}
.form-group {
    margin-bottom: 1rem;
}
.form-control {
    border-radius: 0.5rem;
    padding: 0.75rem 1rem;
}
.form-select {
    border-radius: 0.5rem;
    padding: 0.75rem 1rem;
}
.login-btn {
    width: 100%;
    padding: 0.75rem;
    border-radius: 0.5rem;
    background-color: #667eea;
    border: none;
    color: #fff;
    font-size: 1rem;
    font-weight: 600;
    transition: background-color 0.3s ease;
}
.login-btn:hover {
    background-color: #5469d4;
}
#errorMsg {
    color: #dc3545;
    margin-top: 0.75rem;
    text-align: center;
    min-height: 1.2rem;
}

/* flower */
.shape1,
.shape2 {
  position: absolute;
  width: 150px;
  height: 150px;
  background: rgba(255,255,255,0.2);
  border-radius: 50%;
  z-index: 1;
}

.shape1 {
  top: -50px;
  left: -50px;
}

.shape2 {
  bottom: -50px;
  right: -50px;
}

@media (max-width: 576px) {
    .login-card { padding: 1.5rem; }
}

/* corner flower decoration */
.corner-flower{
    position:absolute;
    right:-18px;
    bottom:-18px;
    width:76px;
    height:76px;
    pointer-events:none;
    transform-origin:center;
    transition:transform 0.35s ease;
    z-index:5;
}
.login-card{position:relative}
.corner-flower svg{width:100%;height:100%;display:block}
.corner-flower:hover{transform:scale(1.06) rotate(6deg)}
.corner-flower .petals{transition:fill 0.25s ease}
