:root{
  --ea-primary:#064023;
  --ea-primary-hover:#0b5a33;
  --ea-primary-soft:#e9f7ef;
  --ea-primary-border:#bfe5ce;
  --ea-title:#06351f;
  --ea-bg:#f4f8f6;
  --ea-muted:#61746a;
}

body{
  background:var(--ea-bg);
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  color:#16241d;
}

a{
  color:var(--ea-primary);
}

.btn-primary,
.btn-primary-custom{
  background:var(--ea-primary)!important;
  border-color:var(--ea-primary)!important;
  color:#fff!important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary-custom:hover{
  background:var(--ea-primary-hover)!important;
  border-color:var(--ea-primary-hover)!important;
  color:#fff!important;
}

.btn-outline-primary{
  color:var(--ea-primary)!important;
  border-color:var(--ea-primary)!important;
}

.btn-outline-primary:hover{
  background:var(--ea-primary)!important;
  color:#fff!important;
}

.btn-outline-success{
  color:var(--ea-primary)!important;
  border-color:var(--ea-primary)!important;
}

.btn-outline-success:hover,
.btn-outline-success:focus{
  background:var(--ea-primary)!important;
  border-color:var(--ea-primary)!important;
  color:#fff!important;
}

.sidebar{
  background:var(--ea-primary)!important;
  color:#fff;
  width:80px;
  height:100vh;
  position:fixed;
  top:0;
  left:0;
  z-index:1040;
}

.sidebar-logo-area,
.sidebar-logo{
  background:#05351e!important;
  border-bottom:1px solid #0a5832;
  min-height:70px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.sidebar-link{
  width:100%;
  padding:20px 0;
  text-align:center;
  color:#fff!important;
  text-decoration:none;
  font-size:1.75rem;
  display:block;
  transition:background .2s;
}

.sidebar-link:hover,
.sidebar-link.active{
  background:var(--ea-primary-hover)!important;
}

.topbar{
  position:fixed;
  left:80px;
  right:0;
  top:0;
  height:70px;
  background:#fff;
  border-bottom:1px solid #d9e5dd;
  z-index:1030;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 20px;
}

.main,
.main-content{
  margin-left:80px;
  margin-top:70px;
  padding:28px 32px;
}

.page-title{
  color:var(--ea-title);
  font-weight:700;
}

.cardx,
.ea-card{
  background:#fff;
  border-radius:16px;
  padding:24px;
  box-shadow:0 4px 22px rgba(6,64,35,.08),0 2px 10px rgba(0,0,0,.04);
  border:1px solid rgba(6,64,35,.05);
}

.mobile-bottom-nav{
  display:none;
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  height:64px;
  background:var(--ea-primary);
  border-top:1px solid #0a5832;
  z-index:1050;
}

.mobile-bottom-nav .nav-content,
.mobile-bottom-nav{
  align-items:center;
  justify-content:stretch;
}

.mobile-bottom-nav a{
  flex:1;
  color:#fff;
  text-decoration:none;
  font-size:1.75rem;
  display:flex;
  align-items:center;
  justify-content:center;
  height:100%;
}

.mobile-bottom-nav a:hover,
.mobile-bottom-nav a.active{
  background:var(--ea-primary-hover);
}

.badge.bg-secondary{
  background:#6c7b72!important;
}

.text-ea-muted{
  color:var(--ea-muted);
}

.alert-ea{
  background:var(--ea-primary-soft);
  border:1px solid var(--ea-primary-border);
  color:#103b26;
  border-radius:12px;
}

.form-control:focus,
.form-select:focus{
  border-color:var(--ea-primary);
  box-shadow:0 0 0 .2rem rgba(6,64,35,.12);
}

.table> :not(caption)>*>*{
  vertical-align:middle;
}

/* =========================================================
   Adjuntos acumulables - Eventos Adversos
   ========================================================= */

.ea-attachment-block{
  margin-top:8px;
  margin-bottom:14px;
  width:100%;
}

.ea-dropzone{
  width:100%;
  border:2px dashed #b8c7bd!important;
  background:#f8fafc!important;
  border-radius:12px!important;
  padding:16px!important;
  cursor:pointer;
  transition:.15s ease-in-out;
  display:block;
  box-shadow:none!important;
}

.ea-dropzone:hover{
  background:#f1f8f4!important;
  border-color:var(--ea-primary)!important;
}

.ea-dropzone.dragover{
  background:var(--ea-primary-soft)!important;
  border-color:var(--ea-primary)!important;
}

.ea-dropzone-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  width:100%;
}

.ea-dropzone-left{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
  flex:1 1 280px;
}

.ea-dropzone-icon{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--ea-primary-soft);
  color:var(--ea-primary);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.35rem;
  flex:0 0 auto;
}

.ea-dropzone-text{
  min-width:0;
  flex:1;
}

.ea-dropzone .dz-title{
  font-weight:700;
  color:#1f2937;
  margin-bottom:2px;
  line-height:1.25;
}

.ea-dropzone .dz-sub{
  color:#6b7280;
  font-size:.92rem;
  line-height:1.35;
}

.ea-dropzone button{
  flex:0 0 auto;
  white-space:nowrap;
}

.ea-file-list{
  margin-top:10px;
}

.ea-file-list .list-group-item{
  border-color:#e5e7eb;
  border-radius:10px!important;
  margin-bottom:6px;
  padding:10px 12px;
}

.file-meta{
  font-size:.85rem;
  color:#6b7280;
}

.file-name{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* Compatibilidad si alguna vista todavía usa .dropzone viejo */
.dropzone{
  border:2px dashed #b8c7bd!important;
  background:#f8fafc!important;
  border-radius:12px!important;
  padding:16px!important;
  cursor:pointer;
  transition:.15s ease-in-out;
}

.dropzone:hover{
  background:#f1f8f4!important;
  border-color:var(--ea-primary)!important;
}

.dropzone.dragover{
  background:var(--ea-primary-soft)!important;
  border-color:var(--ea-primary)!important;
}

.dropzone .dz-title{
  font-weight:700;
  color:#1f2937;
  margin-bottom:2px;
}

.dropzone .dz-sub{
  color:#6b7280;
  font-size:.92rem;
}

/* =========================================================
   Responsive
   ========================================================= */

@media(max-width:991.98px){
  .sidebar{
    display:none;
  }

  .topbar{
    left:0;
  }

  .main,
  .main-content{
    margin-left:0;
    padding:90px 16px 90px;
  }

  .mobile-bottom-nav{
    display:flex;
  }

  .mobile-bottom-nav .nav-content{
    display:flex;
    width:100%;
    height:100%;
  }
}

@media(max-width:576px){
  .ea-dropzone{
    padding:14px!important;
  }

  .ea-dropzone-inner{
    align-items:flex-start;
  }

  .ea-dropzone-left{
    flex:1 1 100%;
  }

  .ea-dropzone button{
    width:100%;
  }
}

@supports(padding:max(0px)){
  .mobile-bottom-nav{
    padding-bottom:max(env(safe-area-inset-bottom),0px);
    height:calc(64px + max(env(safe-area-inset-bottom),0px));
  }

  @media(max-width:991.98px){
    .main,
    .main-content{
      padding-bottom:calc(90px + max(env(safe-area-inset-bottom),0px));
    }
  }
}