/*!------------------------------------------------------------------
[MAIN STYLESHEET]

PROJECT:	Project Name
VERSION:	Versoin Number
-------------------------------------------------------------------*/
/*------------------------------------------------------------------
[TABLE OF CONTENTS]
-------------------------------------------------------------------*/
/*  typography */
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600;700&display=swap");
body {
  line-height: 1.2;
  font-family: "Open Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  color: #B0B0B0; }

p,
.paragraph {
  font-weight: 400;
  color: #B0B0B0;
  font-size: 18px;
  line-height: 1.7;
  font-family: "Open Sans", sans-serif; }

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #E8E8E8;
  font-family: "Open Sans", sans-serif;
  font-weight: 700;
  line-height: 1.4; }

h1,
.h1 {
  font-size: 56px; }
  @media (max-width: 991px) {
    h1,
    .h1 {
      font-size: 48px; } }
  @media (max-width: 767px) {
    h1,
    .h1 {
      font-size: 40px; } }
h2,
.h2 {
  font-size: 48px; }
  @media (max-width: 991px) {
    h2,
    .h2 {
      font-size: 40px; } }
  @media (max-width: 767px) {
    h2,
    .h2 {
      font-size: 32px; } }
h3,
.h3 {
  font-size: 36px; }
  @media (max-width: 991px) {
    h3,
    .h3 {
      font-size: 32px; } }
  @media (max-width: 767px) {
    h3,
    .h3 {
      font-size: 28px; } }
h4,
.h4 {
  font-size: 24px; }

h5,
.h5 {
  font-size: 18px; }

h6,
.h6 {
  font-size: 14px; }

.display-1 {
  font-size: 3.5rem; }
  @media (max-width: 991px) {
    .display-1 {
      font-size: 3rem; } }
  @media (max-width: 767px) {
    .display-1 {
      font-size: 2.5rem; } }
  @media (max-width: 575px) {
    .display-1 {
      font-size: 2rem; } }
/* Button style */
.btn {
  font-size: 16px;
  font-family: "Open Sans", sans-serif;
  text-transform: capitalize;
  padding: 10px 25px;
  border-radius: 5px;
  border: 1px solid;
  position: relative;
  z-index: 1;
  transition: .2s ease; }
  .btn:hover, .btn:active, .btn:focus {
    outline: 0;
    box-shadow: none !important; }

.btn-style {
  position: relative; }
  .btn-style::before {
    position: absolute;
    content: "";
    left: -30px;
    top: 25%;
    height: 50%;
    width: 1px;
    background: #6BA3D6; }
  .btn-style::after {
    position: absolute;
    content: "";
    right: -30px;
    top: 25%;
    height: 50%;
    width: 1px;
    background: #6BA3D6; }

.btn-link {
  padding: 0;
  color: #6BA3D6;
  border: 0;
  text-decoration: underline; }
  .btn-link:hover {
    color: #6BA3D6; }

.btn-link-group a {
  padding: 0;
  color: #6BA3D6;
  border: 0;
  text-decoration: underline; }

.btn-primary {
  background: #6BA3D6;
  color: #F8F8F8;
  border-color: #6BA3D6; }
  .btn-primary:active, .btn-primary:hover, .btn-primary.focus, .btn-primary.active {
    background: #6BA3D6 !important;
    border-color: #6BA3D6 !important; }

.btn-outline-primary {
  background: transparent;
  color: #E8E8E8;
  border-color: #6BA3D6; }
  .btn-outline-primary:active, .btn-outline-primary:hover, .btn-outline-primary.focus, .btn-outline-primary.active {
    background: #6BA3D6 !important;
    border-color: #6BA3D6 !important;
    color: #F8F8F8; }

body {
  background-color: #121212;
  overflow-x: hidden; }

::selection {
  background: #93bce1;
  color: #F8F8F8; }

/* preloader */
.preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center; }

img {
  vertical-align: middle;
  border: 0; }

a {
  color: inherit; }

a,
button,
select {
  cursor: pointer;
  transition: .2s ease; }
  a:focus,
  button:focus,
  select:focus {
    outline: 0; }

a:hover {
  color: #6BA3D6; }

.slick-slide {
  outline: 0; }

.section {
  padding-top: 120px;
  padding-bottom: 120px; }
  @media (max-width: 991px) {
    .section {
      padding-top: 100px;
      padding-bottom: 100px; } }
  @media (max-width: 767px) {
    .section {
      padding-top: 80px;
      padding-bottom: 80px; } }
.bg-cover {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat; }

.outline-0 {
  outline: 0 !important; }

.d-unset {
  display: unset !important; }

.bg-primary {
  background: #6BA3D6 !important; }

.bg-black {
  background: #000000 !important; }

.bg-dark {
  background: #0A0A0A !important; }

.bg-body {
  background: #121212 !important; }

.text-primary {
  color: #6BA3D6 !important; }

.zindex-1 {
  z-index: 1; }

.overflow-hidden {
  overflow: hidden; }

.border-default {
  border-color: #2A2A2A !important; }

.rounded-lg {
  border-radius: 20px !important; }

p:empty {
  display: none; }

.nav-tabs {
  border-color: #2A2A2A; }

.collapse-wrapper > a {
  text-decoration: none !important; }

#particles-js {
  position: fixed;
  width: 100%;
  height: 100vh;
  background-color: #121212;
  z-index: -1; }

.nav-item {
  margin: 0; }
  .nav-item .nav-link {
    text-transform: capitalize; }

.nav-lang {
  margin: 15px 0 15px 10px;
  padding: 0 !important; }
  @media (max-width: 991px) {
    .nav-lang {
      margin: 10px auto; } }
.navbar-dark .navbar-nav .nav-link {
  color: #E8E8E8; }
  .navbar-dark .navbar-nav .nav-link:hover {
    color: #6BA3D6; }

.navbar-expand-lg .navbar-nav .nav-link {
  padding: 20px 15px; }
  @media (max-width: 991px) {
    .navbar-expand-lg .navbar-nav .nav-link {
      padding: 10px 0; } }
.social-icons a {
  display: block;
  font-size: 18px;
  color: #B0B0B0;
  height: 46px;
  width: 46px;
  line-height: 46px;
  border: 1px solid #2A2A2A;
  border-radius: 50%;
  text-align: center;
  transition: .2s ease; }
  .social-icons a:hover {
    color: #6BA3D6;
    border-color: #6BA3D6;
    text-decoration: none; }

.title strong {
  color: #6BA3D6; }

.title-border {
  position: relative;
  margin-bottom: 40px; }
  .title-border::before {
    position: absolute;
    content: "";
    left: 0;
    bottom: -15px;
    height: 1px;
    width: 200px;
    background: #6BA3D6; }

.form-control {
  background: transparent;
  border-radius: 0;
  height: 55px;
  border: 1px solid #2A2A2A;
  color: #E8E8E8; }
  .form-control::placeholder {
    color: #B0B0B0;
    font-size: 14px; }
  .form-control:focus {
    background: transparent;
    box-shadow: none;
    color: #E8E8E8;
    border-color: #6BA3D6; }

textarea.form-control {
  height: 180px; }

.pagination {
  justify-content: center; }
  .pagination .page-item .page-link {
    display: inline-block;
    width: 50px;
    height: 50px;
    line-height: 50px;
    border-radius: 0;
    background: #0A0A0A;
    text-align: center;
    padding: 0;
    font-weight: 600;
    margin-right: 10px;
    border: 0;
    color: #6BA3D6; }
    .pagination .page-item .page-link:hover {
      background: #6BA3D6;
      color: #E8E8E8; }
  .pagination .page-item:first-child .page-link, .pagination .page-item:last-child .page-link {
    border-radius: 0; }
  .pagination .page-item.active .page-link {
    background: #6BA3D6;
    color: #E8E8E8; }

.content * {
  word-break: break-word;
  overflow-wrap: break-word; }

.content h1,
.content h2,
.content h3,
.content h4,
.content h5,
.content h6 {
  font-weight: 500; }

.content strong {
  font-weight: 600; }

.content a {
  text-decoration: underline;
  color: #6BA3D6; }

.content ol,
.content ul {
  padding-left: 20px; }
  .content ol li,
  .content ul li {
    margin-bottom: 10px; }

.content ul {
  padding-left: 0;
  margin-bottom: 20px; }
  .content ul li {
    padding-left: 20px;
    position: relative; }
    .content ul li::before {
      position: absolute;
      content: '';
      height: 8px;
      width: 8px;
      border-radius: 50%;
      background: #6BA3D6;
      left: 3px;
      top: 8px; }

.content table {
  width: 100%;
  max-width: 100%;
  margin-bottom: 1rem;
  border: 1px solid #2A2A2A; }

.content table td,
.content table th {
  padding: .75rem;
  vertical-align: top;
  margin-bottom: 0; }

.content tr:not(:last-child) {
  border-bottom: 1px solid #2A2A2A; }

.content th {
  font-weight: 500; }

.content thead {
  background: #0A0A0A;
  margin-bottom: 0; }
  .content thead tr {
    border-bottom: 1px solid #2A2A2A; }

.content tbody {
  background: #0A0A0A;
  margin-bottom: 0; }

.content .notices {
  margin: 2rem 0;
  position: relative;
  overflow: hidden; }

.content .notices p {
  padding: 10px;
  margin-bottom: 0; }

.content .notices p::before {
  position: absolute;
  top: 2px;
  color: #F8F8F8;
  font-family: "themify";
  font-weight: 900;
  content: "\e717";
  left: 10px; }

.content .notices.note p {
  border-top: 30px solid #6ab0de;
  background: #0A0A0A; }

.content .notices.note p::after {
  content: 'Note';
  position: absolute;
  top: 2px;
  color: #F8F8F8;
  left: 2rem; }

.content .notices.tip p {
  border-top: 30px solid #78C578;
  background: #0A0A0A; }

.content .notices.tip p::after {
  content: 'Tip';
  position: absolute;
  top: 2px;
  color: #F8F8F8;
  left: 2rem; }

.content .notices.info p {
  border-top: 30px solid #F0B37E;
  background: #0A0A0A; }

.content .notices.info p::after {
  content: 'Info';
  position: absolute;
  top: 2px;
  color: #F8F8F8;
  left: 2rem; }

.content .notices.warning p {
  border-top: 30px solid #E06F6C;
  background: #0A0A0A; }

.content .notices.warning p::after {
  content: 'Warning';
  position: absolute;
  top: 2px;
  color: #fff;
  left: 2rem; }

.content blockquote {
  font-size: 20px !important;
  color: #E8E8E8;
  padding: 20px 40px;
  border-left: 2px solid #6BA3D6;
  margin: 40px 0;
  font-weight: bold;
  background: #0A0A0A; }
  .content blockquote p {
    margin-bottom: 0 !important; }

.content pre {
  display: block;
  padding: 9.5px;
  margin: 10px 0px 10px;
  white-space: pre-wrap; }

.content code {
  margin-bottom: 0 !important;
  font-size: 100%; }

.code-tabs {
  border: 1px solid #2A2A2A;
  overflow: hidden;
  margin-bottom: 20px; }
  .code-tabs .nav-tabs {
    margin-bottom: 0; }
    .code-tabs .nav-tabs .nav-item {
      padding-left: 0;
      border-right: 1px solid #2A2A2A; }
      .code-tabs .nav-tabs .nav-item .nav-link {
        text-decoration: none;
        font-weight: 500;
        border: 0; }
      .code-tabs .nav-tabs .nav-item::before {
        display: none; }
      .code-tabs .nav-tabs .nav-item.active {
        background: #6BA3D6; }
        .code-tabs .nav-tabs .nav-item.active .nav-link {
          color: #F8F8F8; }
  .code-tabs .tab-content {
    padding: 20px 15px; }

#experience .title-border,
#education .title-border,
#expertise .title-border {
  margin-bottom: 20px;
  font-size: 1.1rem;
  font-weight: 600; }

#experience p,
#education p,
#expertise p {
  margin-bottom: 0;
  line-height: 1.4;
  font-size: 0.95rem; }

#experience .col-lg-5,
#experience .col-sm-6,
#education .col-lg-5,
#education .col-sm-6,
#expertise .col-lg-5,
#expertise .col-sm-6 {
  margin-bottom: 1.5rem; }

#about p {
  text-align: justify;
  line-height: 1.6; }

#publication .publication-item,
#publication .talk-item,
#talk .publication-item,
#talk .talk-item {
  border-bottom: 1px solid #2A2A2A;
  padding-bottom: 1.5rem;
  margin-bottom: 1.5rem; }
  #publication .publication-item:last-child,
  #publication .talk-item:last-child,
  #talk .publication-item:last-child,
  #talk .talk-item:last-child {
    border-bottom: none;
    margin-bottom: 0; }
  #publication .publication-item h4,
  #publication .talk-item h4,
  #talk .publication-item h4,
  #talk .talk-item h4 {
    margin-bottom: 0.5rem;
    font-size: 1.1rem;
    font-weight: 600;
    color: #E8E8E8; }
  #publication .publication-item p,
  #publication .talk-item p,
  #talk .publication-item p,
  #talk .talk-item p {
    margin-bottom: 0.75rem;
    color: #B0B0B0;
    font-size: 0.9rem; }
  #publication .publication-item .btn-link-group,
  #publication .talk-item .btn-link-group,
  #talk .publication-item .btn-link-group,
  #talk .talk-item .btn-link-group {
    margin-bottom: 0; }
    #publication .publication-item .btn-link-group a,
    #publication .talk-item .btn-link-group a,
    #talk .publication-item .btn-link-group a,
    #talk .talk-item .btn-link-group a {
      background: transparent;
      border: 1px solid #6BA3D6;
      color: #6BA3D6;
      padding: 0.25rem 0.75rem;
      border-radius: 0.25rem;
      text-decoration: none;
      font-size: 0.85rem;
      transition: all 0.3s ease; }
      #publication .publication-item .btn-link-group a:hover,
      #publication .talk-item .btn-link-group a:hover,
      #talk .publication-item .btn-link-group a:hover,
      #talk .talk-item .btn-link-group a:hover {
        background: #6BA3D6;
        color: #F8F8F8; }

.navbar-brand img {
  max-height: 50px;
  width: auto;
  transition: all 0.3s ease; }
  .navbar-brand img:hover {
    transform: scale(1.05); }

/* Medium Integration Styles */
#medium-blogs-container {
  /* Fallback styles for images that fail to load */
  /* Smooth transitions for card interactions */
  /* Link styling consistency */ }
  #medium-blogs-container .spinner-border {
    width: 3rem;
    height: 3rem; }
  #medium-blogs-container .card-img-top {
    height: 200px;
    object-fit: cover;
    background-color: #343a40; }
    #medium-blogs-container .card-img-top::before {
      content: '';
      display: block;
      width: 100%;
      height: 100%;
      background: linear-gradient(45deg, #343a40 25%, transparent 25%), linear-gradient(-45deg, #343a40 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #343a40 75%), linear-gradient(-45deg, transparent 75%, #343a40 75%);
      background-size: 20px 20px;
      background-position: 0 0, 0 10px, 10px -10px, -10px 0px; }
  #medium-blogs-container .card {
    transition: transform 0.2s ease-in-out; }
    #medium-blogs-container .card:hover {
      transform: translateY(-2px); }
  #medium-blogs-container .card-body h4 a {
    color: inherit;
    text-decoration: none; }
    #medium-blogs-container .card-body h4 a:hover {
      color: #6BA3D6;
      text-decoration: none; }

/* Loading animation */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px); }
  to {
    opacity: 1;
    transform: translateY(0); } }

#medium-blogs-container .card {
  animation: fadeIn 0.5s ease-out; }
