@import 'layouts/layout-default';
@import 'layouts/month-left-align';

$theme: ".glass";

@mixin flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

#{$calName}#{$theme} {
  --cal-color-primary: #EC407A;
  --cal-font-family-header: 'Open Sans', sans-serif;
  --cal-font-family-weekdays: 'Open Sans', sans-serif;
  --cal-font-family-body: 'Open Sans', sans-serif;
  --cal-drop-shadow: 0 7px 30px -10px rgba(150, 170, 180, 0.5);
  --cal-border: none;
  --cal-border-radius: 0.5rem;
  --cal-header-color: white;
  --cal-header-background-color: rgba(0, 0, 0, 0.3);

  border-radius: var(--cal-border-radius);
  box-shadow: var(--cal-drop-shadow);
  color: #323232;
  background-color: var(--cal-header-background-color);
  backdrop-filter: blur(5px);
  border: var(--cal-border);
}

#{$calName}#{$theme} .calendar__header {
  padding: 20px 14px 20px 14px;
  color: var(--cal-header-color);
}

#{$calName}#{$theme} .calendar__monthyear {
  font-weight: 700;
  color: var(--cal-header-color);
}

#{$calName}#{$theme} .calendar__arrow {
  &-inner {
    border-radius: 50%;

    &::before {
      content: '';
      width: 0.5em;
      height: 0.5em;
      position: absolute;
      border-style: solid;
      border-width: 0.17em 0.17em 0 0;
      display: inline-block;
      transform-origin: center center;
      transform: rotate(-45deg);
      border-radius: 2px;
      color: var(--cal-header-color);
    }

    &::after {
      content: '';
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 35px;
      height: 35px;
      border-radius: 50%;
      background-color: var(--cal-header-color);
      opacity: 0.12;
      z-index: -1;
      transition: opacity 0.3s ease;
    }

    &:hover {
      &::after {
        transition: opacity 0.3s ease;
        opacity: 0.25;
      }
    }
  }

  &-prev {
    position: relative;
    @include flex-center;

    .calendar__arrow-inner::before {
      margin-left: 0.25em;
      transform: rotate(-135deg);
    }
  }

  &-next {
    position: relative;
    @include flex-center;

    .calendar__arrow-inner::before {
      margin-right: 0.25em;
      transform: rotate(45deg);
    }
  }
}

#{$calName}#{$theme} .calendar__body {
  padding: 18px 14px;
  border-radius: var(--cal-border-radius);
  background-color: white;
}

#{$calName}#{$theme} .calendar__weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(20px, 55px));
  margin-bottom: 5px;

  .calendar__weekday {
    font-weight: 700;
    opacity: 0.5;
  }
}

#{$calName}#{$theme} .calendar__days {
  .calendar__day-other {
    color: #323232;
    opacity: 0.2;
  }

  .calendar__day {
    font-weight: 600;
  }

  .calendar__day-today {
    font-weight: 700;
    color: var(--cal-color-primary);

    .calendar__day-box {
      border-radius: 0.5rem;
      background-color: var(--cal-color-primary);
      opacity: 0.1;
    }
  }

  .calendar__day-text {
    &:hover ~ .calendar__day-box {
      opacity: 0.1;
    }
  }

  .calendar__day-bullet {
    background-color: var(--cal-color-primary);

    &:hover ~ .calendar__day-box {
      opacity: 0.1;
    }
  }

  .calendar__day-box {
    border-radius: 0.5rem;
    background-color: var(--cal-color-primary);
    box-shadow: 0 3px 15px -5px var(--cal-color-primary);

    &:hover {
      opacity: 0.1;
    }
  }

  .calendar__day-event {
    font-weight: 700;
  }

  .calendar__day-selected {
    color: white;
    font-weight: 700;

    .calendar__day-box {
      border-radius: 0.5rem;
      background-color: var(--cal-color-primary);
      opacity: 1;
      box-shadow: 0 3px 15px -5px var(--cal-color-primary);
    }

    .calendar__day-text {
      &:hover ~ .calendar__day-box {
        opacity: 1;
      }
    }
  
    .calendar__day-bullet {
      background-color: white;
  
      &:hover ~ .calendar__day-box {
        opacity: 1;
      }
    }
  }
}

#{$calName}#{$theme} .calendar__picker {
  background-color: white;
  border-radius: var(--cal-border-radius);

  &-month {
    &-today {
      box-shadow: inset 0px 0px 0px 1px var(--cal-color-primary);
    }
  }

  &-year {
    &-today {
      box-shadow: inset 0px 0px 0px 1px var(--cal-color-primary);
    }
  }
}

// COMPACT MODE
#{$calName}#{$theme}.color-calendar--small {
  font-size: 0.8rem;

  .calendar__header {
    padding: 10px 10px;
    grid-template-columns: repeat(7, minmax(25px, 41px));

    .calendar__monthyear {
      font-size: 1.2rem;
    }

    .calendar__arrow-inner, .calendar__arrow-inner::after {
      width: 30px;
      height: 30px;
    }
  }

  .calendar__body {
    padding: 10px 10px;

    .calendar__weekdays {
      grid-template-columns: repeat(7, minmax(25px, 41px));
      margin-bottom: 0;
    }

    .calendar__days {
      grid-template-columns: repeat(7, minmax(25px, 41px));
      grid-template-rows: repeat(6, minmax(30px, 35px));
    }

    .calendar__picker {
      top: 55px;

      .calendar__picker-month {
        &-option {
          padding: 10px 0;
        }
        &-option::after {
          height: 40px;
        }
      }
      .calendar__picker-year {
        &-option {
          padding: 10px 0;
        }
        &-option::after {
          height: 40px;
        }
      }
    }
  }
}
