:host {
  /*@doc Define o tamanho da fonte do header.*/
  --ez-collapsible-box--font-size: var(--title--medium, 14px);
  /*@doc Define a família da fonte do header.*/
  --ez-collapsible-box--font-family: var(--font-pattern, Arial);
  /*@doc Define o peso da fonte do header.*/
  --ez-collapsible-box--font-weight: var(--text-weight--large, 600);
  /*@doc Define a cor da fonte do header.*/
  --ez-collapsible-box--color: var(--title--primary);
  /*@doc Define o tamanho da fonte do header.*/
  --ez-collapsible-box--subtitle--font-size: var(--text--medium, 14px);
  /*@doc Define a família da fonte do header.*/
  --ez-collapsible-box--subtitle--font-family: var(--font-pattern, 'Roboto');
  /*@doc Define o peso da fonte do header.*/
  --ez-collapsible-box--subtitle--font-weight: var(--text-weight--medium, 400);
  /*@doc Define a cor da fonte do header.*/
  --ez-collapsible-box--subtitle--color: var(--text--primary);
  /*@doc Define a cor da fonte do header.*/
  --ez-collapsible-box--subtitle--margin-bottom: var(--space--medium, 12px);
   /*@doc Define a cor do texto e do ícone quando o componente está focado.*/
   --ez-collapsible-box--focus--color: var(--color--primary-600);
  /*@doc Define a cor do chevron.*/
  --ez-collapsible-box__icon--color: var(--ez-collapsible-box--color);
  /*@doc Define o espaçamento superior ao header.*/
  --ez-collapsible-box__header--padding-top: 0px;
  /*@doc Define o espaçamento inferior ao header.*/
  --ez-collapsible-box__header--padding-bottom: 0px;
  /*@doc Define o espaçamento à direita do header.*/
  --ez-collapsible-box__header--padding-right: 0px;
  /*@doc Define o espaçamento à esquerda do header.*/
  --ez-collapsible-box__header--padding-left: 0px;

  /***************
     host style  
  ***************/
  /*private*/
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

ez-icon {
  --ez-icon--color: inherit;
}

.collapsible-box {
  /*private*/
  display: flex;
  flex-direction: column;
  width: 100%;
  overflow: hidden;
}


.collapsable-box--bordered {
  border: var(--border--small);
  border-color: var(--color--strokes);
  border-radius: var(--border--radius-medium);
  padding: var(--space--xs);
}

.collapsible-box__header {
  /*private*/
  display: flex;
  box-sizing: border-box;
  
  /*public*/
  padding-top: var(--ez-collapsible-box__header--padding-top);
  padding-bottom: var(--ez-collapsible-box__header--padding-bottom);
  padding-right: var(--ez-collapsible-box__header--padding-right);
  padding-left: var(--ez-collapsible-box__header--padding-left);
}

.collapsible-box__title {
  /*private*/
  position: relative;
  width: 100%;
  display: flex;
  box-sizing: border-box;
  align-items: center;
  outline: none;
  border: none;
  background-color: unset;
  cursor: pointer;
  padding: 0px;
  text-align: left;

  /*public*/
  color: var(--ez-collapsible-box--color);
  --ez-icon--color: var(--ez-collapsible-box__icon--color);
  margin-bottom: var(--space--medium, 12px);
}

.collapsible-box__title:focus {
  /*public*/
  color: var(--ez-collapsible-box--focus--color);
  --ez-icon--color: var(--ez-collapsible-box--focus--color);
}

.collapsible-box__label {
  /*private*/
  display: flex;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
  text-overflow: ellipsis;
  box-sizing: border-box;
  margin-left: 6px;
  gap: 6px;

  /*public*/
  font-family: var(--ez-collapsible-box--font-family);
  font-size: var(--ez-collapsible-box--font-size);
  font-weight: var(--ez-collapsible-box--font-weight);
}

.subtitle-box__label {
  /*private*/
  display: flex;
  overflow: hidden;
  text-overflow: ellipsis;
  box-sizing: border-box;

  /*public*/
  font-family: var(--ez-collapsible-box--subtitle--font-family);
  font-size: var(--ez-collapsible-box--subtitle--font-size);
  font-weight: var(--ez-collapsible-box--subtitle--font-weight);
  color: var(--ez-collapsible-box--subtitle--color);
  margin-bottom: var(--ez-collapsible-box--subtitle--margin-bottom);
}

.subtitle-box__content{
  /*private*/
  width: 100%;
}

.collapsible-box__label ez-icon {
  visibility: hidden;
  transition: 2s all ease-in-out;
}

.collapsible-box__label:hover ez-icon {
  visibility: visible;
}

.collapsible-box__text-edit {
  /*private*/
  margin-left: 6px;
}

.collapsible-box__icon {
  /*private*/
  transform: rotate(90deg) translate(0px, 14%);

  /*public*/
  transition: transform var(--transition);
}

.collapsible-box__icon--collapsed {
  /*private*/
  transform: rotate(0deg) translate(-14%, 0px);
}

.collapsible-box__title--icon-right {
  /*private*/
  flex-direction: row-reverse;
}

.collapsible-box__title--icon-right .collapsible-box__icon {
  /*private*/
  transform: rotate(90deg) translate(0px, -14%);
}

.collapsible-box__title--icon-right .collapsible-box__icon--collapsed {
  /*private*/
  transform: rotate(0deg) translate(14%, 0px);
}

.collapsible-box__title--icon-right .collapsible-box__label {
  /*private*/
  margin-left: 0px;
  margin-right: 6px;
}

.collapsible-box__title--left {
  margin-right: auto;
}

.collapsible-box__title--right {
  margin-left: auto;
}

.collapsible-box__title--center {
  margin-left: auto;
  margin-right: auto;
}

.collapsible-box__title--stretch {
  justify-content: space-between;
  width: 100%;
}

.collapsible-box__title--no-margin {
  margin-bottom: 0;
}

.collapsible-box__content {
  /*private*/
  display: flex;
  flex-wrap: wrap;
  
  width: 100%;
  height: 0px;
  max-height: 0px;
  opacity: 0;
  overflow: hidden;

  /*public*/
  transition: all var(--transition, 0.5s);
}

.collapsible-box__content--show {
  /*private*/
  height: 100%;
  max-height: none;
  opacity: 1;
  overflow: visible;

  /*public*/
  transition: all var(--transition, 0.5s);
}

.font--x-small {
  /*private*/
  font-size: 10px;
}

.font--small {
  /*private*/
  font-size: 12px;
}

.font--medium {
  /*private*/
  font-size: 14px;
}

.font--large {
  /*private*/
  font-size: 16px;
}

.font--x-large {
  /*private*/
  font-size: 20px;
}