/* 
  Theme Name: Liikenneopetus v2
  Author: Opetustarvike Oy
  Version: 1.0.0
  Description: A custom block theme with full site editing support
  Text Domain: liikenneopetus-v2
  Domain Path: /languages
*/

:root {
  --wc-form-border-color: #d2d2d2;
  --ld-color-brand-primary: #c14f3e !important;
  --ld-color-primitives-blue-500: #c14f3e !important;
}

*,
*:before,
*:after {
  box-sizing: border-box;
}

*:focus-visible {
  outline: 3px solid var(--wp--preset--color--attention);
  outline-offset: 2px;
}

html {
  scroll-behavior: smooth;
}

body {
  -webkit-font-smoothing: antialiased;
}

main {
  margin: 0 !important;
}

.px-main {
  padding-inline: clamp(1rem, 5dvw, 3rem);
}

header.wp-block-template-part,
footer.wp-block-template-part {
  margin: 0;

  .wp-block-image a {
    display: flex;

    img {
      object-fit: contain;
    }
  }
}

header.wp-block-template-part {
  position: sticky;
  top: 0;
  z-index: 99;

  .header-logo-desktop a {
    padding-block: clamp(0.5rem, 3dvw, 2rem);
  }
}

footer.wp-block-template-part {
  ul {
    list-style: none;
    padding: 0;

    li a {
      display: block;
      padding-block: 0.4em;
      text-decoration: none;

      &:hover {
        color: var(--wp--preset--color--attention-on-dark);
        text-decoration: underline;
      }
    }
  }
}

.grid-cols-auto-1fr {
  display: grid;
  gap: var(--wp--preset--spacing--50);
  grid-template-columns: auto 1fr;
  align-items: start;
}

.grid-cols-2 {
  display: grid;
  gap: var(--wp--preset--spacing--50);
  grid-template-columns: repeat(2, 1fr);

  > div {
    width: 100%;
  }
}

.grid-cols-3 {
  display: grid;
  gap: var(--wp--preset--spacing--50);
  grid-template-columns: repeat(3, 1fr);

  > div {
    width: 100%;
  }

  li {
    margin: 0 !important;
  }
}

.card {
  border: solid 1px color-mix(in srgb, var(--wp--preset--color--attention) 20%, transparent);
  border-radius: 16px;
}

.card-shadow {
  box-shadow: 0 4px 4px 0px rgba(0, 0, 0, 0.05);
}

.h-full {
  height: 100%;
}

.wp-block-query-pagination {
  font-weight: 700;

  * {
    text-decoration: none;
  }

  a,
  :active,
  a:visited {
    color: var(--wp--preset--color--attention);
  }

  a:hover,
  a:focus {
    background-color: var(--wp--preset--color--text-color);
    color: var(--wp--preset--color--white-bg);
  }

  .wp-block-query-pagination-previous,
  .wp-block-query-pagination-next,
  .page-numbers {
    border-radius: 100vw;
    padding: 0.5rem 1rem;
    background-color: var(--wp--preset--color--light-bg);
    font-size: var(--wp--preset--font-size--small);
    border: 2px solid var(--wp--preset--color--attention);
  }

  .wp-block-query-pagination-numbers {
    display: flex;
    gap: 0.5rem;

    .page-numbers.current {
      background-color: var(--wp--preset--color--attention);
      color: var(--wp--preset--color--white-bg);
    }
  }
}

.header-nav-desktop {
  display: none !important;

  .wp-block-navigation-item {
    &.current-menu-ancestor,
    &.current-menu-item > a > .wp-block-navigation-item__label {
      font-weight: 900;
      text-decoration: underline;
    }

    > a:hover {
      text-decoration: underline;
    }
  }

  ul.wp-block-navigation__submenu-container {
    background-color: var(--wp--preset--color--light-bg) !important;
    border-radius: 16px !important;
    min-width: max-content !important;
    overflow: hidden !important;
    padding: 0.75rem 0.5rem;
    box-shadow: 0 4px 4px 0px rgba(0, 0, 0, 0.05);

    li.wp-block-navigation-item {
      font-size: var(--wp--preset--font-size--small) !important;
      font-weight: 700;

      &.wp-block-navigation-link {
        color: var(--wp--preset--color--attention);
      }
    }
  }
}

.header-nav-mobile {
  .wp-block-navigation__responsive-dialog {
    padding-inline: clamp(1.15rem, 5dvw, 3rem);
  }

  .wp-block-navigation__responsive-container-close {
    top: 1rem;
    right: 1rem;

    > svg {
      height: 2rem;
      width: 2rem;
    }
  }

  &.wp-block-navigation__container {
    width: 100%;
    gap: 0 !important;
  }

  .wp-block-navigation__submenu-container {
    padding: 0 0 1rem 1.5rem !important;
  }

  .wp-block-navigation-item__content {
    font-size: var(--wp--preset--font-size--large);
    padding-block: 1rem !important;
  }

  .wp-block-navigation-item {
    .dropbtn {
      padding-block: 1rem !important;
      font-size: var(--wp--preset--font-size--large);
    }

    &.current-menu-item > a > .wp-block-navigation-item__label {
      font-weight: 900;
      color: var(--wp--preset--color--attention) !important;
      text-decoration: underline;
    }
  }
}

.wp-block-button.is-style-outline {
  &:hover a {
    color: var(--wp--preset--color--dark-bg);
    background-color: var(--wp--preset--color--light-bg);
  }
}
.dropdown {
  --text-color: #fff;
  --text-color-active: var(--wp--preset--color--dark-bg);
  --bg-color: #fff;
  --outline-border: #d9d9d9;

  position: relative;
  width: max-content;

  > .dropbtn {
    display: flex;
    align-items: center;
    padding: 0.5em 1em;
    border: 1px solid var(--wp--preset--color--attention);
    border-radius: 16px;
    background: none;
    font-family: inherit;
    font-size: inherit;
    color: inherit;
    transition: padding 0.1s linear;

    &::after {
      content: '';
      border-bottom: 2px solid var(--text-color);
      border-right: 2px solid var(--text-color);
      height: 0.5em;
      width: 0.5em;
      transform: rotate(45deg);
    }

    &[aria-expanded='true'] {
      background-color: var(--bg-color);
      border-color: var(--outline-border);
      border-bottom: 0;
      border-radius: 16px 16px 0 0;
      padding-block: 1rem;
      color: var(--text-color-active);

      &::after {
        border-color: var(--text-color-active);
      }
    }

    &[aria-expanded='true'] ~ .dropdown-content {
      display: block;
      background-color: var(--bg-color);
      box-shadow: 0 4px 4px 0px rgba(0, 0, 0, 0.05);
      border: 1px solid var(--outline-border);
      border-top: 0;
    }
  }

  > .dropdown-content {
    display: none;
    position: absolute;
    width: max-content;
    border-radius: 0 16px 16px 16px;
    padding: 1em;
    z-index: 99;
    color: var(--text-color-active);
    background-color: var(--bg-color);

    a {
      padding-block: 0.5em;
      color: var(--text-color-active);
    }
  }
}

.wc-block-mini-cart {
  .wc-block-mini-cart__button {
    border: 1px solid var(--wp--preset--color--attention);
    border-radius: 1rem;
    padding: 0.2em 0.7em;
  }
}

@media (hover: hover) and (pointer: fine) {
  /* .dropdown {
    &:hover {
      .dropbtn {
        background-color: var(--bg-color);
        color: var(--text-color-active);
      }
    }
  } */

  .wc-block-mini-cart {
    .wc-block-mini-cart__button:hover {
      border-color: #fff;
      background-color: #fff;

      svg {
        color: var(--wp--preset--color--dark-bg);
        fill: currentColor;
      }
    }
  }
}

.overflow-hidden {
  overflow: hidden;
}

.text-decoration-none * {
  text-decoration: none !important;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

.break-word {
  word-break: break-word;
}

@media only screen and (max-width: 900px) {
  .grid-cols-3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media only screen and (max-width: 600px) {
  .grid-cols-auto-1fr,
  .grid-cols-2,
  .grid-cols-3 {
    grid-template-columns: repeat(1, 1fr);
  }

  .text-center-mobile {
    text-align: center;
  }
}

@media (min-width: 800px) {
  .header-nav-mobile {
    display: none !important;
  }
  .header-nav-desktop {
    display: flex !important;
  }
}

.wp-block-navigation-item__content {
  display: flex !important;
  align-items: center;
  gap: 1.25rem;
}

.nav-icon svg,
.wp-block-navigation-item__content svg {
  width: 3em;
  height: 1.5em;
}

.wp-block-navigation__container > .wp-block-navigation-item {
  border-radius: 1em;
  border: 1px solid var(--wp--preset--color--attention);
  padding: 0.2em 0.8em !important;

  &.has-child:hover,
  &:has(.wp-block-navigation-submenu__toggle[aria-expanded='true']) {
    border: 1px solid #00000026;
    border-radius: 1em 1em 0 0;
    background-color: var(--wp--preset--color--light-bg);
    color: var(--wp--preset--color--dark-bg);
    padding-block: 1em !important;
    transition: all 0.1s linear;
  }
}

.wp-block-navigation .has-child > .wp-block-navigation__submenu-container {
  min-width: max-content !important;
  padding: 1em 0 !important;
  box-shadow: 0 4px 4px 0px rgba(0, 0, 0, 0.05);
  border-top: none;
  border-radius: 0 1em 1em 1em;
  overflow: hidden !important;

  .wp-block-navigation-item a {
    padding: 0.75em 1.5em;

    &:hover {
      color: var(--wp--preset--color--attention);
      text-decoration: underline;
    }
  }
}

.woocommerce-MyAccount-navigation {
  display: none !important;
}

.woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
  color: var(--wp--preset--color--white-bg);

  #billing_first_name_field,
  #billing_last_name_field {
    float: none !important;
    width: 100% !important;
  }

  .wc-block-components-notice-banner {
    margin: var(--wp--preset--spacing--50);
  }

  table.shop_table {
    background-color: var(--wp--preset--color--white-bg);
    color: var(--wp--preset--color--text-color);
  }

  .woocommerce-customer-details {
    address {
      border-color: #fff;
    }
  }
}

.woocommerce-EditAccountForm {
  br {
    display: none;
  }

  label[for='account_display_name'],
  #account_display_name {
    display: none;
  }
}

.woocommerce form .form-row .required {
  color: red;
}

fieldset {
  border: 1px solid var(--wc-form-border-color);
  border-radius: var(--wc-form-border-radius);
  padding: 1em;

  legend {
    padding-inline: 0.25em;
  }
}

.no-margin-bottom {
  margin-bottom: 0 !important;
}

.woocommerce-orders-table__cell-order-number a {
  display: flex;
}

.wc-block-components-notice-banner {
  display: flex;
  align-items: center;
}

.account-course-listing {
  --red: #ffb8a1;
  --green: #008021;
  --yellow: #ffe93f;

  display: grid;
  gap: 1em;
  margin-top: 1.5em;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));

  .course-wrapper {
    display: grid;
    align-content: start;
    grid-template-rows: auto 1fr;
  }

  .course-status {
    display: inline-block;
    width: fit-content;
    background-color: var(--red);
    padding: 0 0.75em;
    position: relative;
    border-radius: 6px 6px 0 0;
    font-size: 14px;
    color: #000;

    &[data-status='in_progress'] {
      background-color: var(--yellow);
      color: #000;
    }
    &[data-status='completed'] {
      background-color: var(--green);
      color: #fff;
      font-weight: 700;
    }
  }
  .card {
    background-color: var(--wp--preset--color--white-bg);
    color: var(--wp--preset--color--text-color);
    overflow: hidden;
    border-radius: 0px 16px 16px;

    .icons {
      padding: 0.7em 1em 0.5em;
      background-color: #faf3ef;
      border-bottom: 1px solid #d8c0b4;
      justify-content: center;
    }

    .content {
      padding: 0.8em;
    }

    h3 {
      margin: 0;
      font-size: var(--wp--preset--font-size--medium);
    }

    p {
      font-size: var(--wp--preset--font-size--small);
    }

    .badge {
      width: fit-content;
    }
  }

  .badge[data-expired='true'] {
    background-color: #d00;
    color: #fff;
    font-weight: 700;
  }
}

@media (min-width: 600px) {
}

@media (max-width: 599px) {
  .wp-block-navigation__responsive-container {
    background-color: var(--wp--preset--color--dark-bg) !important;
    color: #fff !important;
  }
  .wp-block-navigation__responsive-container-content {
    font-size: var(--wp--preset--font-size--medium) !important;
    padding-inline: 1em;
  }
  .wp-block-navigation__container {
    width: 100%;
  }
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-container-content
    .wp-block-navigation-item.wp-block-navigation-submenu {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;

    &:has(.wp-block-navigation-submenu__toggle[aria-expanded='true']) {
      background-color: var(--wp--preset--color--light-bg) !important;
      color: var(--wp--preset--color--dark-bg) !important;
      border-radius: 1em;
      width: 100%;

      .wp-block-navigation__submenu-container {
        box-shadow: none;
      }
    }

    > .wp-block-navigation-item__content {
      grid-column: 1;
    }

    > .wp-block-navigation__submenu-icon {
      grid-column: 2;
      justify-self: end;
      display: flex;
      justify-content: end;
      align-items: center;
      height: 100%;
      width: 100%;

      svg {
        height: 1em;
        width: 1em;
      }
    }

    .wp-block-navigation__submenu-container {
      display: none;
      width: 100%;
      grid-column: 1 / -1;
    }
  }

  .dropdown .dropdown-content {
    position: relative;
  }

  .ld-layout__content .material-lang {
    flex-shrink: 0;
    width: 1.5em;
  }

  .ld-layout__content .uo-tincanny-content {
    flex-grow: 1;
  }
}

dialog#header-mobile-menu:popover-open {
  transform: translateX(0);
}

dialog#header-mobile-menu {
  position: fixed;
  inset: 0;
  background-color: rgb(0, 0, 0);
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 1em;
  border: none;
  color: #fff;

  transform: translateX(100%);

  transition: transform 400ms ease-in-out, overlay 0.7s allow-discrete, display 0.7s allow-discrete;
}

@starting-style {
  dialog#header-mobile-menu:popover-open {
    transform: translateX(100%);
  }
}

.icon-container {
  display: grid;
  gap: 6px;
  justify-items: center;
  align-items: center;
  font-size: var(--wp--preset--font-size--small);
  font-weight: 600;

  * {
    margin: 0;
    padding: 0;
  }

  .dlc-icon {
    display: inline-block;
    width: auto;
    height: 24px;
  }
}

svg {
  width: auto;
  height: 100%;
}

.flex {
  display: flex;
  gap: 1em;
  flex-wrap: wrap;
}

.padding-50 {
  padding: var(--wp--preset--spacing--50);
}

.border-radius-bottom {
  border-radius: 0 0 16px 16px;
}

.badge {
  border-radius: 6px;
  font-size: var(--wp--preset--font-size--small);
  padding: 0.25em 0.7em;
  background-color: #faf3ef;
  font-size: 14px;
}

.ld-progress-bar__meter-foreground {
  background-color: #83b70e;
}

.learndash-wrapper .ld-progress .ld-progress-heading .ld-progress-stats .ld-progress-percentage {
  font-weight: 700 !important;
}

.ld-featured-image--course {
  display: none;
}

.wc-block-components-product-price .woocommerce-Price-amount {
  font-weight: 700;
}

.wc-block-components-product-price del .woocommerce-Price-amount {
  font-weight: 400;
}

.wc-block-product.sale .card {
  border-top-left-radius: 0;
}

.product-type-woosb form.cart .quantity {
  display: none;
}

.woocommerce span.onsale {
  background-color: #ff5400;
  min-height: unset;
  min-width: unset;
  padding: 1em;
  line-height: normal;
}

.wc-block-product-description {
  h3 {
    background-color: #faf3ef;
    padding: 1em;
    border-left: 2px solid var(--wp--preset--color--attention);
    margin-top: 1em;
    font-size: 1.25em;
  }

  hr {
    height: 1px;
    border: 0;
    background-color: #d2d2d2;
  }
}

.wp-block-add-to-cart-with-options {
  form.cart {
    margin-bottom: 0 !important;
    margin-top: var(--wp--preset--spacing--60);
  }
}

.learndash_post_sfwd-courses.user_has_no_access .learndash-wrapper {
  display: block !important;

  .ld-layout__sidebar {
    display: none;
  }
}

.woocommerce-account .woocommerce {
  color: #fff;

  .woocommerce-form-login {
    br {
      display: none;
    }
    .woocommerce-form-login__rememberme {
      display: block;
    }
    .woocommerce-form-login__submit {
      float: none;
    }
  }
  .woocommerce-ResetPassword {
    br {
      display: none;
    }
  }
}

body:not(.logged-in) {
  .hide-when-not-logged-in {
    display: none;
  }
}

body.logged-in {
  .hide-when-logged-in {
    display: none;
  }
}

.order-again .button {
  display: inline-block;
}

.woocommerce-cart .wp-block-post-title,
.woocommerce-checkout .wp-block-post-title {
  max-width: 1200px !important;
}

.woocommerce-order-details .woocommerce-table__line-item {
  font-size: var(--wp--preset--font-size--small);
}

.wc-block-cart-item__product .wc-block-components-sale-badge {
  background-color: #769c51;
  color: #fff;
  border-radius: 100dvw;
  border: none;
}

.margin-left-auto {
  margin-left: auto;
}

.wp-block-button:hover {
  &.btn-on-dark > .wp-element-button {
    background-color: #fff !important;
    color: var(--wp--preset--color--text-color) !important;
  }
}

.woosb-before-text {
  font-size: var(--wp--preset--font-size--small);
  font-weight: 600;
  color: #6b6b6b;
}

.woosb-price {
  text-decoration: line-through;
}

.xapi-state-status {
  width: max-content;
}

.wc-paytrail-ppa-methods {
  .wc-paytrail-ppa-method-group-title {
    display: grid;
    grid-template-columns: 2em 1fr;
    align-items: center;
    gap: 0.5em;
    background-color: #eaeaea;
    padding: 0.5em 0.75em;
    font-weight: 400;
    margin-bottom: 0.5em;
  }

  .wc-paytrail-ppa-method-group-title::before {
    content: '';
    display: inline-block;
    height: 2em;
    background-size: contain;
    background-repeat: no-repeat;
  }

  #wc-paytrail-ppa-method-group-title-bank::before {
    background-image: url('https://resources.paytrail.com/images/payment-group-icons/bank.png');
  }

  #wc-paytrail-ppa-method-group-title-mobile::before {
    background-image: url('https://resources.paytrail.com/images/payment-group-icons/mobile.png');
  }

  #wc-paytrail-ppa-method-group-title-creditcard::before {
    background-image: url('https://resources.paytrail.com/images/payment-group-icons/creditcard.png');
  }

  #wc-paytrail-ppa-method-group-title-credit::before {
    background-image: url('https://resources.paytrail.com/images/payment-group-icons/credit.png');
  }

  .wc-paytrail-ppa-method {
    position: relative;
    border: none !important;
    outline: 2px solid #eaeaea;
    outline-offset: -2px;
    padding-block: 0.5em;

    &.selected {
      outline: 3px solid var(--wp--preset--color--attention);
      outline-offset: -3px;
      background-color: #fffaf8;
    }

    input[type='radio'] {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
    }
  }
}
