@import url('./Roboto_Flex/roboto_flex.css');
@import url('./Roboto_Slab/roboto_slab.css');
@import url('./Roboto_Mono/roboto_mono.css');
@import url('./Roboto_Condensed/roboto_condensed.css');

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

  /* https://kilianvalkhof.com/2022/css-html/your-css-reset-needs-text-size-adjust-probably/ */
  html {
    -moz-text-size-adjust: none;
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
    scroll-padding: 2rem;
  }
  @media (prefers-reduced-motion: no-preference) {
    html {
      scroll-behavior: smooth;
    }
  }

  body,
  h1,
  h2,
  h3,
  h4,
  p,
  figure,
  blockquote,
  dl,
  dd {
    margin: 0;
  }

  /* https://www.scottohara.me/blog/2019/01/12/lists-and-safari.html */
  [role="list"] {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  body {
    min-block-size: 100vh;
    line-height: 1.6;
  }

  h1,
  h2,
  h3,
  button,
  input,
  label {
    line-height: 1.1;
  }

  h1,
  h2,
  h3,
  h4 {
    text-wrap: balance;
  }

  p,

  li {
    text-wrap: pretty;
  }

  img,
  picture {
    max-inline-size: 100%;
    display: block;
  }

  input,
  button,
  textarea,
  select {
    font: inherit;
  }
}
@layer global_vars {
    /* primitives */

  :root {
  /* Neutrals - Light Theme */
      --clr-white-100: rgb(245, 243, 237);
      --clr-white-200: rgb(237, 233, 227);
      --clr-white-300: hsla(35, 20%, 92%, 1);
      --clr-white-400: hsla(35, 15%, 85%, 1);
      --clr-white-500: hsla(35, 12%, 75%, 1);
      
      --clr-gray-400: hsla(35, 8%, 58%, 1);
      --clr-gray-500: hsla(35, 8%, 40%, 1);
      --clr-gray-600: hsla(35, 8%, 28%, 1);
      --clr-gray-700: hsla(36, 9%, 21%, 1);
      --clr-gray-800: hsla(30, 10%, 18%, 1);
      
      /* Neutrals - Dark Theme */
      --clr-blue-100: hsla(210, 65%, 95%, 1);
      --clr-blue-200: hsla(210, 60%, 90%, 1);
      --clr-blue-300: hsla(215, 25%, 73%, 1);
      --clr-blue-400: hsla(215, 20%, 57%, 1);
      --clr-blue-500: hsla(215, 25%, 40%, 1);
      
      --clr-navy-100: hsla(210, 35%, 26%, 1);
      --clr-navy-200: hsla(212, 40%, 21%, 1);
      --clr-navy-300: hsla(214, 43%, 19%, 1);
      --clr-navy-400: hsla(214, 45%, 15%, 1);
      --clr-navy-500: hsla(214, 50%, 12%, 1);
      
      /* Accents */
      --clr-orange-300: hsla(25, 85%, 67%, 1);
      --clr-orange-400: hsla(25, 78%, 62%, 1);
      --clr-orange-500: hsla(25, 65%, 54%, 1);
      
      /* font family */
      --ff-body: "Roboto Flex", sans-serif;
      --ff-heading: "Roboto Slab", serif;
      --ff-console: "Roboto Mono", sans-serif;
      --ff-caption: "Roboto Condensed", sans-serif;
      --ff-subheading: "Roboto Condensed", sans-serif;
      /* font sizes */
      --fs-300: 0.875rem;
      --fs-400: 1rem;
      --fs-500: 1.125rem;
      --fs-600: 1.25rem;
      --fs-700: 1.5rem;
      --fs-800: 1.75rem;
      --fs-900: 3.75rem;
      --fs-1000: 3.75rem;
      @media (width > 760px) {
          --fs-300: 0.875rem;
          --fs-400: 1rem;
          --fs-500: 1.25rem;
          --fs-600: 1.5rem;
          --fs-700: 2rem;
          --fs-800: 2.5rem;
          --fs-900: 3rem;
          --fs-1000: 5rem;
      }
  }
  /* semantic layer */
  :root {
    --text-main: var(--clr-gray-800);
    --text-main-muted: var(--clr-gray-600);
    --text-high-contrast: var(--clr-white-100);
    --text-brand: var(--clr-orange-500);
    --text-brand-light: var(--clr-orange-400);

    --background-accent-light: var(--clr-orange-300);
    --background-accent-main: var(--clr-orange-400);
    --background-accent-dark: var(--clr-orange-500);

    --background-extra-light: var(--clr-white-100);
    --background-light: var(--clr-white-200);
    --background-main: var(--clr-white-300);
    --background-dark: var(--clr-white-400);
    --background-extra-dark: var(--clr-white-500);
    --background-dark-transparent: hsla(35, 15%, 85%, 0.7);

    --font-size-heading-sm: var(--fs-700);
    --font-size-heading-regular: var(--fs-800);
    --font-size-heading-lg: var(--fs-900);
    --font-size-heading-xl: var(--fs-1000);

    --font-size-sm: var(--fs-300);
    --font-size-regular: var(--fs-400);
    --font-size-md: var(--fs-500);
    --font-size-lg: var(--fs-600);

    --border-radius-1: 0.25rem;
    --border-radius-2: 0.5rem;
    --border-radius-3: 0.75rem;
  }   
  html[data-theme="dark"] {
    --text-main: var(--clr-blue-100);
    --text-main-muted: var(--clr-blue-200);

    --text-high-contrast: var(--clr-gray-800);
    --background-extra-light: var(--clr-navy-100);
    --background-light: var(--clr-navy-200);
    --background-main: var(--clr-navy-300);
    --background-dark: var(--clr-navy-400);
    --background-extra-dark: var(--clr-navy-500);
    --background-dark-transparent: hsla(214, 45%, 15%, 0.7);
  }
}
@layer base {
  html {
      font-family: var(--ff-body);
      line-height: 1.6;
  }
  body {
      font-family: var(--ff-body);
      font-size: var(--font-size-md);
      font-size: var(--font-size-regular);
      color: var(--text-main);
      background-color: var(--background-main);
  }
  h1, h2, h3, h4, h5, h6 {
      font-family: var(--ff-heading);
      font-size: var(--font-size-heading-regular);
      color: var(--text-main);
      &[data-heading-size="large"] {
        font-size: var(--font-size-heading-xl);
      }
      &[data-heading-size="small"] {
        font-size: var(--font-size-heading-sm);
      }
  }

  .navigation-menu {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-inline: auto;


    @media (width < 855px) {
      ul[data-buttons="true"] {
        gap: 0.5rem;
        a {
          font-size: var(--font-size-md);
        }
      }
    }
  }

  ul[data-buttons="true"] {
    display: flex;
    gap: 1rem;
  }

  ul[data-buttons="true"] a {
    text-decoration: none;
    color: var(--text-main-muted);
    font-family: var(--ff-heading);
    font-size: var(--font-size-heading-sm);

    &:hover {
      cursor: pointer;
      font-weight: 600;
      color: var(--background-accent-main);
    }

    &[aria-current="page"] {
      font-weight: 600;
      border-bottom: 2px dashed var(--background-accent-main);
    }
  }

  a {
    text-decoration: underline;
    color: var(--text-brand-light);
    font-family: var(--ff-body);

    &:hover {
      cursor: pointer;
      color: var(--text-brand);
    }
  }
}

@layer layout {

  .flow * + * {
    margin-top: var(--flow-spacer, 1em);
  }

  .flow[data-flow-margin="compact"] {
    --flow-spacer: 0.5em;
  }
  .section {
    --padding: 1rem;
    padding-block: var(--padding);
    
    &[data-padding="collapsed"] {
      --padding: 0;
    }

    &[data-padding="compact"] {
      --padding : 1.5rem;
    }
    &[data-padding="wide"] {
      --padding : 2.5rem;
    }
    @media (width < 880px) {
      --padding: 1.8rem;
    }
    .wrapper {
      min-height: 18ch;
    }
  }
  
  .wrapper {
    --wrapper-padding: 1rem;
    --max-width: 770px;

    max-width: var(--max-width);
    padding-inline: var(--wrapper-padding);
    margin-inline: auto;

    &[data-width="narrow"] {
      --max-width: 450px;
    }

    &[data-width="wide"] {
      --max-width: 1150px;
    }

    &[data-width="full"] {
      --max-width: 100%;
    }
  }
  .country-cards-section {
    background-color: var(--background-extra-light);
  }
  .country-cards-wrapper {
    --cards-gap: 1rem;
    --cards-padding: 1.5rem;
    display: flex;
  }

  .not-found-section {
    text-align: center;
    margin: 0 auto;
  }

  .markdown-blog-content {
    h2, h3, h4, h5, h6 {
      font-size: var(--font-size-heading-sm);
    }
  }
}

@layer components {
  .hero {
    background: linear-gradient(to bottom, var(--background-dark), var(--background-extra-dark));
    border-radius: var(--border-radius-3);
    padding: 1.5rem 1rem;
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
  }

  .hero-content {
    flex: 1 1 300px;
    padding-left: 1rem;
    min-width: 300px;
    font-family: var(--ff-console);
    text-wrap: pretty;
    p {
      font-size: var(--font-size-md);
    }
  }

  .passions-container {
    background-color: var(--background-dark);
    border-radius: var(--border-radius-2);
    padding: 1rem 1.25rem;
    margin-top: 1.5rem;
  }

  .passions-container h3 {
    font-size: var(--font-size-md);
    margin-bottom: 0.5rem;
  }

  .hero-profile-picture {
    flex: 0 0 330px;
    width: 330px;
    aspect-ratio: 3 / 4;
    border-radius: var(--border-radius-2);
    overflow: hidden;
    border: 3px solid var(--background-accent-main);
  }

  .hero-profile-picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .passions-list {
    list-style: none;
    margin-inline: 0;
    padding-left: 0;
    font-family: var(--font-size-regular);
  }

  .passions-list li {
    color: var(--text-main);
    margin-bottom: 0.5rem;
    padding-left: 1.5rem;
    position: relative;
  }

  .passions-list li::before {
    content: "✱";
    position: absolute;
    left: 0;
    color: var(--background-accent-main);
    font-weight: 400;
  }

  @media (width < 800px) {
    .hero {
      flex-direction: column-reverse;
      text-align: center;
      border-radius: 0;
    }
    
    .hero-profile-picture {
      margin: 0 auto;
    }

    .hero-content, .passions-list {
      text-align: left;
    }
  }
  .country-cards-wrapper {
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    align-self: center;
    gap: var(--cards-gap);
    flex-wrap: wrap;
    padding-block: var(--cards-padding);
    margin-inline: auto;
    @media (width > 760px) {
      --cards-gap: 1.5rem;
      --cards-padding: 3rem;
      max-width: 85%;
    }

    h2 {
      width: 100%;
      text-align: center;
    }
  }

  .country-card {
    position: relative;
    --card-width: 16rem;
    --card-height: 20rem;
    --card-padding: 0rem;
    flex: 0 0 var(--card-width);
    min-height: var(--card-height);
    padding: var(--card-padding);
    background-color: var(--background-light);
    border-radius: var(--border-radius-3);

    @media (width > 760px) {
      --card-width: 18.75rem;
      --card-height: 21.875rem;
      --card-padding: 0;
    }

    @media (width < 520px) {
      --card-width: 85%;
      --card-height: 18rem;
    }

    .country-card-text {
      --font-size-sm: 1.2rem;
      font-size: var(--font-size-sm);
      color: var(--text-main-muted);
      position: absolute;
      text-wrap: pretty;
      padding-inline: 1ch;
      background-color: var(--background-dark-transparent);
      border-radius: var(--border-radius-1);
      backdrop-filter: blur(4px);
    }

    .country-card-text[data-country-name="🇮🇳 Hyderabad, India"] {
      top: 120px;
      right: 10px;
    }

    .country-card-text[data-country-name="🇧🇳 Brunei"] {
      bottom: 10rem;
      right: 2rem;
    }

    .country-card-text[data-country-name="🇸🇬 Singapore"] {
      bottom: 8rem;
      left: 1rem;
    }

    .country-card-text[data-country-name="🇨🇦 Canada"] {
      bottom: 8rem;
      left: 4rem;
    }

    .country-card-text[data-country-name="🇬🇧 United Kingdom"] {
      top: 80px;
      right: 10px;
    }

    .country-card-context {
      position: absolute;
      bottom: 1rem;
      width: fit-content;
      margin-inline: auto;
      left: 0;
      right: 0;
      font-size: var(--font-size-regular);
      font-family: var(--ff-heading);
      color: var(--text-main);
      font-weight: 400;
      text-align: center;
    }
  }
  .theme-toggle {
    --icon-fill: var(--text-main-muted);
    --icon-fill-hover: var(--background-accent-main);

    background: none;
    border: none;
    padding: 0;
    inline-size: 2rem;
    block-size: 2rem;
    aspect-ratio: 1;
    border-radius: 50%;
    cursor: pointer;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    outline-offset: 5px;
    align-self: center;

    @media (width < 855px) {
      inline-size: 1.5rem;
      block-size: 1.5rem;
    }
  }

  .theme-toggle > svg {
    inline-size: 100%;
    block-size: 100%;
    stroke-linecap: round;
  }

  .sun-and-moon > :is(.moon, .sun, .sun-beams) {
    transform-origin: center;
  }

  .sun-and-moon > :is(.moon, .sun) {
    fill: var(--icon-fill);
  }

  .theme-toggle:is(:hover, :focus-visible) > .sun-and-moon > :is(.moon, .sun) {
    fill: var(--icon-fill-hover);
  }

  .sun-and-moon > .sun-beams {
    stroke: var(--icon-fill);
    stroke-width: 2px;
  }

  .theme-toggle:is(:hover, :focus-visible) .sun-and-moon > .sun-beams {
    stroke: var(--icon-fill-hover);
  }

  [data-theme="dark"] .sun-and-moon > .sun {
    transform: scale(1.75);
  }

  [data-theme="dark"] .sun-and-moon > .sun-beams {
    opacity: 0;
  }

  [data-theme="dark"] .sun-and-moon > .moon > circle {
    transform: translateX(-7px);
  }

  @supports (cx: 1) {
    [data-theme="dark"] .sun-and-moon > .moon > circle {
      cx: 17;
      transform: translateX(0);
    }
  }

  @media (prefers-reduced-motion: no-preference) {
    .sun-and-moon > .sun {
      transition: transform .5s cubic-bezier(.5, 1.25, .75, 1.25);
    }

    .sun-and-moon > .sun-beams {
      transition:
        transform .5s cubic-bezier(.5, 1.5, .75, 1.25),
        opacity .5s cubic-bezier(.25, 0, .3, 1);
    }

    .sun-and-moon .moon > circle {
      transition: transform .25s cubic-bezier(.5, 0, .75, 0);
    }

    @supports (cx: 1) {
      .sun-and-moon .moon > circle {
        transition: cx .25s cubic-bezier(.5, 0, .75, 0);
      }
    }

    [data-theme="dark"] .sun-and-moon > .sun {
      transition-timing-function: cubic-bezier(.25, 0, .3, 1);
      transition-duration: .25s;
      transform: scale(1.75);
    }

    [data-theme="dark"] .sun-and-moon > .sun-beams {
      transition-duration: .15s;
      transform: rotateZ(-25deg);
    }

    [data-theme="dark"] .sun-and-moon > .moon > circle {
      transition-duration: .5s;
      transition-delay: .25s;
    }
  }

  .content-card-head {
    font-family: "Roboto Slab", serif;
    gap: 0.75em;
    a {
      font-size: var(--font-size-md);
      font-family: "Roboto Slab", serif;
    }
    h2 {
      text-wrap: pretty;
    }
  }
  
  .content-card-text {
    margin-inline: 0.7rem;
    margin-top: 1rem;

    h3 {
      font-size: var(--font-size-lg);
      margin-bottom: 0.5rem;
    }
    p {
      color: var(--text-main-muted);
      line-height: 1.6;
    }
  }
  
  
  button[data-button-type="muted"] {
    padding: 0.25rem 0rem;
    background-color: transparent;
    color: var(--text-brand-light);
    border: none;
    border-radius: var(--border-radius-1);
    cursor: pointer;
    font-family: var(--ff-heading);
    font-size: var(--font-size-sm);
    text-decoration: underline;
  }
  
  button[data-button-type="muted"]:hover {
    color: var(--text-brand);
  }
  
  button[data-button-type="accent"] {
    padding: 0.5rem 0.75rem;
    background-color: var(--background-accent-main);
    color: var(--text-high-contrast);
    border: none;
    border-radius: var(--border-radius-1);
    cursor: pointer;
    font-family: var(--ff-heading);
    font-size: var(--font-size-regular);
  }
  button[data-button-type="accent"]:hover {
    background-color: var(--background-accent-dark);
  }
  

  .post-title-link {
    display: flex;
    flex-direction: column;
    gap: var(--card-gap);
    margin-top: var(--card-height);

    h2 {
      font-size: var(--font-size-heading-sm);
    }
    time {
      font-family: var(--ff-console);
    }
  }

  .content-card {
    --card-image-height: 20rem;
    --card-gap: 1rem;
    --card-padding: 0.5rem;
    background-color: var(--background-extra-light);
    display: flex;
    gap: var(--card-gap);
    padding: var(--card-padding);
    flex-wrap: wrap;

    &:hover {
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
      cursor: pointer;
    }
    &[data-has-image="true"] img {
      width: 100%;
      height: var(--card-image-height);
      object-fit: cover;
      margin-block: 0;
    }
  }
  
  .project-carousel {
    --carousel-dot-size: var(--fs-300);
    --carousel-dot-gap: 1rem;
    --carousel-dot-radius: 50%;
    --carousel-dots-margin: var(--padding);
    margin-block: 2rem;
    position: relative;
    overflow: hidden;
  }

  .project-carousel__track {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    gap: var(--card-gap, var(--padding));
    scroll-behavior: smooth;
  }

  .project-carousel__track::-webkit-scrollbar {
    display: none;
  }

  .project-carousel__track .content-card {
    flex: 0 0 100%;
    scroll-snap-align: start;
  }

  .project-carousel__dots {
    display: flex;
    justify-content: center;
    gap: var(--carousel-dot-gap);
    margin-top: var(--carousel-dots-margin);
  }

  .project-carousel__dot {
    width: var(--carousel-dot-size);
    height: var(--carousel-dot-size);
    border-radius: var(--carousel-dot-radius);
    background: var(--background-extra-light);
    transition: background 0.2s;
  }

  .project-carousel__dot.is-active {
    background: var(--background-accent-main);
  }

  .comment-section h2 {
    font-size: var(--font-size-heading-sm);
    margin-bottom: 1rem;
  }
  .comment-section form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 2rem;

    button {
      max-width: 100px;
    }
  }

  .comment-textarea {
    padding: 0.75rem;
    border: 1px solid var(--background-dark);
    border-radius: var(--border-radius-1);
    background-color: var(--background-light);
    color: var(--text-main);
    min-height: 100px;
    resize: vertical;
  }

  .comment-textarea:focus {
    outline: 2px solid var(--background-accent-main);
    outline-offset: 2px;
  }

  .comment-textarea:disabled {
    cursor: not-allowed;
  }

  .comment-form-btn {
    min-width: 180px;
    &:disabled {
      cursor: progress;
      background-color: var(--background-accent-dark);
    }
  }

  .comment-section [x-show="loading"] {
    padding: 2rem;
    text-align: center;
    color: var(--text-main-muted);
    font-style: italic;
  }

  .comment {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    background-color: var(--background-extra-light);
    border-radius: var(--border-radius-1);
    padding: 1rem;
  }

  .comment-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    --flow-spacer: 0rem;
  }

  .comment button[data-button-type="muted"] {
    --flow-spacer: 0rem;
    align-self: flex-start;
  }

  .powerbi-embed-wrapper {
    width: 100%;
    overflow-x: auto;
  }

  .powerbi-embed-wrapper iframe {
    display: block;
  }
}

@layer utilities {
}