/* Mobile-first + polished UI */
:root{
  --card-radius: 16px;
  --btn-radius: 12px;
}

body{
  font-family: system-ui, -apple-system, "Segoe UI", Tahoma, Arial, sans-serif;
  background:
    radial-gradient(900px 300px at 10% 0%, rgba(13,110,253,.10), transparent 60%),
    radial-gradient(900px 300px at 90% 0%, rgba(25,135,84,.10), transparent 60%),
    #f8f9fa;
}

.navbar{
  backdrop-filter: blur(6px);
}

.card{
  border-radius: var(--card-radius);
  border: 1px solid rgba(0,0,0,.06);
}

.btn{
  border-radius: var(--btn-radius);
}

.form-control, .form-select{
  border-radius: var(--btn-radius);
}

.table{
  margin-bottom: 0;
}

.nav-tabs .nav-link{
  border-radius: 12px 12px 0 0;
}

.list-group-item{
  border-color: rgba(0,0,0,.06);
}

.badge{
  border-radius: 10px;
}

/* ---------------------------
   Company branding on reports
   --------------------------- */
.report-header{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  background:#fff;
  margin-bottom:12px;
}
.report-logo{
  width:56px;
  height:56px;
  object-fit:contain;
  border-radius:50%;
  border:1px solid rgba(0,0,0,.10);
  background:#fff;
}
.report-logo--placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
}
.report-header__company{
  font-weight:700;
  font-size:1.05rem;
  line-height:1.2;
}
.report-header__meta{
  font-size:.85rem;
  color:#6c757d;
}

/* Print-friendly */
@media print {
  /* Hide nav and non-print elements */
  .navbar, .no-print { display:none !important; }

  body { background:#fff !important; }

  .report-header{ 
    border:1px solid #ddd;
    page-break-inside:avoid;
  }
  .report-logo{ width:72px; height:72px; }
}

.app-navbar{
  background: rgba(255,255,255,.92) !important;
}

.company-chip{
  padding: .55rem .8rem;
  font-size: .8rem;
}

.app-main{
  min-height: calc(100vh - 150px);
  padding-bottom: 6rem;
}

.app-nav-links .btn{
  min-height: 42px;
}

.mobile-bottom-nav{
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  z-index: 1040;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: .35rem;
  padding: .5rem .6rem calc(.5rem + env(safe-area-inset-bottom));
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(0,0,0,.08);
}

.mobile-bottom-nav__link{
  color: #212529;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .2rem;
  padding: .45rem .2rem;
  border-radius: 14px;
  font-size: .72rem;
}

.mobile-bottom-nav__link i{
  font-size: 1.05rem;
}

.mobile-bottom-nav__link:hover,
.mobile-bottom-nav__link:focus{
  background: rgba(13,110,253,.08);
  color: #0d6efd;
}

.notes-fab{
  bottom: 1rem;
}

@media (max-width: 991.98px){
  body{
    background:
      radial-gradient(600px 220px at 10% 0%, rgba(13,110,253,.08), transparent 60%),
      radial-gradient(600px 220px at 90% 0%, rgba(25,135,84,.08), transparent 60%),
      #f8f9fa;
  }

  .container{
    padding-inline: .9rem;
  }

  .card-body{
    padding: 1rem;
  }

  .table-responsive{
    border-radius: 14px;
  }

  .table{
    font-size: .92rem;
  }

  .app-nav-links .btn{
    width: 100%;
    justify-content: center;
  }

  .notes-fab{
    bottom: 5.6rem;
  }
}

@media (min-width: 992px){
  .app-main{
    padding-bottom: 2rem;
  }
}

.project-media-card{
  overflow: hidden;
}

.project-media-thumb{
  width: 100%;
  height: 240px;
  object-fit: cover;
  background: #eef2f7;
  display: block;
}

@media (max-width: 767.98px){
  .project-media-thumb{
    height: 220px;
  }
}


/* Project actions layout */
.project-actions {
  align-items: center;
}
.project-actions .btn,
.project-actions form {
  flex: 0 0 auto;
}
@media (max-width: 1399px) {
  .project-actions {
    row-gap: .4rem;
  }
}


.avatar-nav, .avatar-thumb, .profile-avatar {
  object-fit: cover;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f8f9fa;
  color: #495057;
  font-weight: 700;
}
.avatar-nav { width: 28px; height: 28px; font-size: .8rem; }
.avatar-thumb { width: 38px; height: 38px; font-size: .9rem; }
.profile-avatar { width: 108px; height: 108px; font-size: 2rem; margin: 0 auto; }
.avatar-nav--placeholder, .avatar-thumb--placeholder, .profile-avatar--placeholder { display: inline-flex; }

@media print {
  .navbar, .mobile-bottom-nav, .notes-fab, .offcanvas, .btn, .print-hide, .alert {
    display: none !important;
  }
  .container, .container-fluid, .app-main {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .card { border: 1px solid #ccc !important; box-shadow: none !important; }
}
