/* General */

#family-tree {
    font-family: "Lato", sans-serif;
    padding: 2rem;
    width: 100%;
    margin: 0;
    display: flex;
    align-items: start;
    justify-content: start;
    position: relative;
    height: 100%;
    min-height: 100vh;
    margin-top: 40px;
}

.name {
    font-size: 1rem;
}

.dates {
    margin-top: .15rem;
    font-size: .8rem;
    display: flex;
    gap: .25rem;
}

.member.m { background: #cce5ff; }
.member.f { background: #f8d7da; }
.member.x { background: #e2e3e5; }

.member img {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    margin-bottom: 5px;
}

.member img.icon {
    width: 10px;
    height: 10px;
    border-radius: 0;
    margin-bottom: 0px;
}

.member {
    padding: 1rem;
    border: 2px solid #000;
}

.member.m + .member.f {
    border-left: 0px;
}

.member.m + .member.f + .member.f {
    border-left: 0px;
}

.member.m + .member.f + .member.f + .member.f {
    border-left: 0px;
}


.member-info {
    position: relative;
}

.country img {
    height: 15px;
    width: auto;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}

.location {
    display: flex;
    gap: .25rem;
    font-size: .8rem;
    margin-top: .25rem;
}

.parent-group > .family-group > .member-group > .inner > .member.m {
    border-top-right-radius: 0rem;
    border-bottom-right-radius: 0rem;
}

.parent-group > .family-group > .member-group > .inner > .member.f {
    border-top-left-radius: 0rem;
    border-bottom-left-radius: 0rem;
}

.member img {
    margin-bottom: 0px;
}

.member-group .inner {
    display: flex;
    padding-bottom: 2rem;
    position: relative;
}

ul.parent-group,
ul.child {
    list-style: none;
    padding: 0rem 2rem;
    margin: 0;
    position: relative;
}

/* Diagram View */

.diagram-view .child-group {
    display: flex;
    justify-content: center;
}

.diagram-view .member-group .inner {
    justify-content: center;
    margin-bottom: 2rem;
}

.diagram-view .member {
    width: 200px;
    gap: .5rem;
    position: relative;
    display: flex;
    align-items: center;
    flex-direction: column;
}

.diagram-view .member-info {
    text-align: center;
}

.diagram-view .dates,
.diagram-view .location {
    justify-content: center;
}

/* Linien */

.diagram-view .member-group:before {
    content: "";
    position: absolute;
    border-right: 2px solid #000;
    height: 2rem;
    width: 50%;
    top: -2rem;
    left: 0;
}

.diagram-view .member-group > .inner:after {
    content: "";
    position: absolute;
    border-right: 2px solid #000;
    height: 2rem;
    width: 50%;
    bottom: 0rem;
    left: 0;
}

.diagram-view .child.end .member-group > .inner:after {
    border-right: 2px dotted #000;
}

.diagram-view .child-group > ul > .family-group > .member-group:after {
    content: "";
    position: absolute;
    border-top: 2px solid #000;
    height: 2rem;
    width: calc(100% + 4rem);
    top: -2rem;
    right: -2rem;
    left: -2rem;
}

.diagram-view .child-group > ul:first-of-type > .family-group > .member-group:after {
    content: "";
    position: absolute;
    border-top: 2px solid #000;
    height: 2rem;
    width: calc(50% + 2rem);
    top: -2rem;
    right: -2rem;
    left: auto;
}

.diagram-view .child-group > ul:last-of-type > .family-group > .member-group:after {
    content: "";
    position: absolute;
    border-top: 2px solid #000;
    height: 2rem;
    width: calc(50% + 2rem);
    top: -2rem;
    right: auto;
    left: -2rem;
}

.diagram-view .child-group > ul:only-of-type > .family-group > .member-group:after {
    content: "";
    position: absolute;
    border-top: 0px solid #000;
    height: 2rem;
    width: calc(100% + 4rem);
    top: -2rem;
    right: -2rem;
    left: -2rem;
}

/* List View */

.list-view > #family-tree > ul.parent-group {
    padding-left: 0rem;
}

.list-view .inner:before {
    content: "";
    position: absolute;
    border-bottom: 2px solid #000;
    height: calc(50% + 1rem);
    width: 2rem;
    top: -2rem;
    left: -2rem;
    margin-top: -1px;
}

.list-view .child-group > ul:before {
    content: "";
    position: absolute;
    border-left: 2px solid #000;
    height: 100%;
    width: 2rem;
    top: -2rem;
    left: 0rem;
}

.list-view .child-group > ul:first-of-type:before {
    height: 100%;
}

.list-view .child-group > ul:last-of-type:before {
    height: 65%;
}

.list-view .child.end .member-group > .inner .member:after {
    content: "";
    position: absolute;
    border-bottom: 2px dotted #000;
    height: 50%;
    width: 2rem;
    top: 0;
    right: -2rem;
    margin-top: -1px;
}

.list-view ul.parent-group, 
.list-view ul.child {
    margin-left: 2rem;
}

.list-view #family-tree > ul.parent-group {
    margin-left: 0rem;
}

.list-view .member {
    width: 300px;
    gap: 1rem;
    position: relative;
    display: flex;
    align-items: center;
    flex-direction: row;
}

/* Control */

.control {
    position: fixed;
    top: 0rem;
    left: 0rem;
    display: flex;
    z-index: 9999;
    width: 100%;
    justify-content: space-between;
}

.control button {
    height: 40px;
    width: 100%;
    min-width: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fff !important;
    border: 2px solid #000;
    border-right: 0px;
}

.control button:last-of-type {
    border-right: 2px solid #000;
}

.control button img {
    height: 20px;
    width: auto;
}

#reset {
    font-weight: 600;
}

/* PLus/Minus */

.plus-1 #family-tree {
  transform: scale(1.1);
  transform-origin: top left;
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -ms-transform: scale(1.1);
  -o-transform: scale(1.1);
}

.plus-2 #family-tree {
  transform: scale(1.2);
  transform-origin: top left;
  -webkit-transform: scale(1.2);
  -moz-transform: scale(1.2);
  -ms-transform: scale(1.2);
  -o-transform: scale(1.2);
}

.plus-3 #family-tree {
  transform: scale(1.3);
  transform-origin: top left;
  -webkit-transform: scale(1.3);
  -moz-transform: scale(1.3);
  -ms-transform: scale(1.3);
  -o-transform: scale(1.3);
}

.plus-4 #family-tree {
  transform: scale(1.4);
  transform-origin: top left;
  -webkit-transform: scale(1.4);
  -moz-transform: scale(1.4);
  -ms-transform: scale(1.4);
  -o-transform: scale(1.4);
}

.plus-5 #family-tree {
  transform: scale(1.5);
  transform-origin: top left;
  -webkit-transform: scale(1.5);
  -moz-transform: scale(1.5);
  -ms-transform: scale(1.5);
  -o-transform: scale(1.5);
}

.minus-1 #family-tree {
  transform: scale(0.9);
  transform-origin: top left;
  -webkit-transform: scale(0.9);
  -moz-transform: scale(0.9);
  -ms-transform: scale(0.9);
  -o-transform: scale(0.9);
}

.minus-2 #family-tree {
  transform: scale(0.8);
  transform-origin: top left;
  -webkit-transform: scale(0.8);
  -moz-transform: scale(0.8);
  -ms-transform: scale(0.8);
  -o-transform: scale(0.8);
}

.minus-3 #family-tree {
  transform: scale(0.7);
  transform-origin: top left;
  -webkit-transform: scale(0.7);
  -moz-transform: scale(0.7);
  -ms-transform: scale(0.7);
  -o-transform: scale(0.7);
}

.minus-4 #family-tree {
  transform: scale(0.6);
  transform-origin: top left;
  -webkit-transform: scale(0.6);
  -moz-transform: scale(0.6);
  -ms-transform: scale(0.6);
  -o-transform: scale(0.6);
}

.minus-5 #family-tree {
  transform: scale(0.5);
  transform-origin: top left;
  -webkit-transform: scale(0.5);
  -moz-transform: scale(0.5);
  -ms-transform: scale(0.5);
  -o-transform: scale(0.5);
}

.minus-6 #family-tree {
  transform: scale(0.4);
  transform-origin: top left;
  -webkit-transform: scale(0.4);
  -moz-transform: scale(0.4);
  -ms-transform: scale(0.4);
  -o-transform: scale(0.4);
}

.minus-7 #family-tree {
  transform: scale(0.3);
  transform-origin: top left;
  -webkit-transform: scale(0.3);
  -moz-transform: scale(0.3);
  -ms-transform: scale(0.3);
  -o-transform: scale(0.3);
}

.minus-8 #family-tree {
  transform: scale(0.2);
  transform-origin: top left;
  -webkit-transform: scale(0.2);
  -moz-transform: scale(0.2);
  -ms-transform: scale(0.2);
  -o-transform: scale(0.2);
}

.minus-9 #family-tree {
  transform: scale(0.1);
  transform-origin: top left;
  -webkit-transform: scale(0.1);
  -moz-transform: scale(0.1);
  -ms-transform: scale(0.1);
  -o-transform: scale(0.1);
}