
body.fade-in { transition: opacity .4s ease-in; }
.navbar .entity { display: flex; align-items: center; gap: 1rem; padding: .25rem .75rem; }
.entity-nav { display: flex; list-style: none; margin: 0; padding: 0; gap: .75rem; }
.entity-link { text-decoration: none; color: #333; font-weight: 500; }
.icon { width: 28px; height: 28px; }
.logo { height: 40px; }
.country-selector { display: flex; align-items: center; gap: .5rem; margin-left: 1rem; }
.flag-icon { width: 28px; height: 18px; object-fit: cover; border-radius: 2px; }
.text-country h4 { margin: 0 0 0 1rem; font-size: 1rem; color: #555; }
.nav-signup, .nav-login { display: inline-block; padding: .35rem .75rem; border-radius: .5rem; text-decoration: none; margin-left: .5rem; }
.nav-signup { background: #0d6efd; color: #fff; }
.nav-login { border: 1px solid #0d6efd; color: #0d6efd; }
.nav-login.active { background: #0d6efd; color: #fff; }

.form-box { width: 100%; max-width: 420px; padding: 2rem; border-radius: 1rem; background: #fff; box-shadow: 0 10px 25px rgba(0,0,0,.08); }
.form-box h2 { text-align: center; margin-bottom: 1rem; }
.form-box input { width: 100%; padding: .80rem 1rem; margin-bottom: .8rem; border: 1px solid #e5e7eb; border-radius: .75rem; outline: none; }
.form-box input:focus { border-color: #0d6efd; box-shadow: 0 0 0 .15rem rgba(13,110,253,.15); }
.form-box button { width: 100%; padding: .8rem 1rem; border: 0; border-radius: .75rem; background: #0d6efd; color: #fff; font-weight: 600; }
.form-box p { text-align: center; margin-top: .6rem; }

.footer { background: #f8f9fa; margin-top: 3rem; padding: 2rem 0; }
.footer-content { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1rem; }
.footer-section h4 { font-size: 1rem; margin-bottom: .75rem; }
.footer-section ul { list-style: none; padding: 0; margin: 0; }
.footer-section li { margin: .25rem 0; }
.footer-section a { color: #333; text-decoration: none; }
.footer-section a:hover { text-decoration: underline; }
.footer-logo { height: 40px; margin-bottom: .5rem; }
.social-links { display: flex; gap: .75rem; list-style: none; padding: 0; margin: .5rem 0 0; }
.footer-bottom { margin-top: 1rem; border-top: 1px solid #e5e7eb; padding-top: .75rem; }

@media (max-width: 768px) {
  .footer-content { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
