﻿@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

body {
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    color: rgb(148, 163, 184) !important;
}
/*#wrapper {
    overflow-y: auto;
}
#wrapper:has(.container-fluid.hm-page) {
    overflow-y:clip;
}*/
    .text-slate {
        letter-spacing: -.025em;
    }

.bg-color {
    background-color: rgb(15 23 42 / 1);
}

.text-white-50 {
    color: rgb(148, 163, 184) !important;
}

.text-white {
    color: rgb(226 232 240 / 1) !important;

}
#social {
    position: inherit;
    bottom: 0;
}
.guard {
    position: inherit;
}


.nav {
    --bs-nav-link-padding-x: 0rem;
}
/* Hide scrollbar for Chrome/Safari */
.scrollspy-example::-webkit-scrollbar {
    display: none;
}

/*Hide scrollbar for Firefox*/
.scrollspy-example {
    scrollbar-width: none;
}
.sticky-header {
    transition: backdrop-filter 0.2s ease, background-color 0.2s ease;
    z-index:9000;
}

    .sticky-header.title {
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        background-color: rgba(15, 23, 42, 0.75);
    }



/* NAVIGATION LINK STYLING */
#scrollspy-select .nav-link {
    position: relative;
    display: flex;
    align-items: center;
    color: rgb(148, 163, 184);
    font-size: 12px;
    transition: color 0.1s ease;
    background-color: transparent;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
}
    /* Horizontal line before label */
    #scrollspy-select .nav-link::before {
        content: '';
        display: inline-block;
        width: 2rem;
        height: 1.5px;
        background-color: rgb(148, 163, 184);
        margin-right: 0.5rem;
        flex-shrink: 0;
        transition: width 0.1s ease, background-color 0.1s ease;
    }
    /* Hover and Active effects */
    #scrollspy-select .nav-link:hover::before,
    #scrollspy-select .nav-link.active::before {
        width: 3.5rem;
        background-color: rgb(226 232 240 / 1);
    }

    /*#scrollspy-select .nav-link:hover,*/
    #scrollspy-select .nav-link.active {
        color: rgb(226 232 240 / 1) !important;
    }
.text-head {
    transition: color 0.3s ease;
}
.card-hv:hover .text-head {
    color: rgb(94 234 212 / 1) !important;
}

.card-hv .mdi-arrow-top-right {
    position: absolute;
    transition: transform 0.1s ease;
}
.link-with-arrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem; /* optional, for spacing between icon and text */
    transition: color 0.1s ease;
}

.arrow-icon {
    transition: transform 0.1s ease;
}

.link-with-arrow:hover .arrow-icon {
    transform: translateX(-7px);
}


.card-hv:hover .mdi-arrow-top-right {
    transform: translate(3px, -3px);
}
.text-xs {
    font-size: 12px;
}
.text-sm {
    font-size:14px;
}
.text-md {
    font-size: 16px;
}
.card-hv {
    background-color: transparent;
    backdrop-filter: blur(0px);
    -webkit-backdrop-filter: blur(0px);
    transition: background-color 0.1s ease, padding 0.1s ease, box-shadow 0.1s ease;
}


.text-teal {
    color: rgb(94 234 212 / 1);
}

.bg-teal {
    background-color: rgba(45, 212, 191, .1);
}


.table {
    border-collapse: collapse;
    width: 100%;
}

    .table > :not(caption) > * > * {
        padding: 1.25rem 1rem;
        color: inherit;
        background-color: transparent;
        border: 0 solid rgba(255, 255, 255, 0.05); /* subtle but visible */
        vertical-align: middle;
    }
    .table thead th {
        font-weight: 700;
        font-size: .875rem;
        line-height: 1.25rem;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        border-bottom: 0.025em solid rgba(255, 255, 255, 0.08); /* darker bottom line for header */
    }

thead th {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08); /* slightly stronger header underline */
}

tbody td {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

/* Optional: make horizontal rule stand out more */
.table tr:not(:last-child) td {
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
/* Custom narrow column for year */
.col-year {
    width: 0px; /* or try 70px / 6rem */
    white-space: nowrap;
}

@media (min-width: 992px) {
    .guard {
        position: fixed;
    }
    .card-hv.card:hover {
        background-color: rgba(255, 255, 255, 0.05);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
    }
    body:has(.card-hv:not(.view-resume):hover) .card-hv:not(.view-resume):not(:hover) {
        opacity: 0.5;
        transition: opacity 0.3s ease;
    }

}
@media (min-width: 992px) and (max-height: 500px) {
    #social {
        display:none !important;
    }
}
.error-text {
    font-family: "Segoe UI", "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 20px;
}
.error-text-sm {
    font-size: 12px;
}




  /* Tweak one variable to resize the whole grid */
  .hex-grid { --hex-size: 150px; --hex-gap: 1rem; --hex-border: #ffffff; --hex-bg: #0c1b2a; }

  /* Honeycomb stagger (matches your screenshot) */
  .hex-item:nth-child(even) { margin-top: calc(var(--hex-size) / 4); }

  /* Outer hex = white border */
  .hex-outer {
    width: var(--hex-size);
    aspect-ratio: 1 / 1;                    /* perfect square that we clip to a hexagon */
    display: grid;
    place-items: center;
    text-decoration: none;
    clip-path: polygon(25% 6.7%, 75% 6.7%, 100% 50%, 75% 93.3%, 25% 93.3%, 0% 50%);
    background: var(--hex-border);
    transition: transform .2s ease;
  }

  /* Inner hex = actual fill */
  .hex-inner {
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    clip-path: inherit;                      /* same hex clip */
    display: grid;
    place-items: center;
    background:
      radial-gradient(120% 100% at 30% 20%, rgba(255,255,255,.12), rgba(255,255,255,0) 40%),
      var(--hex-bg);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
    transition: box-shadow .2s ease, transform .2s ease;
  }

  /* Icon sizing: works for <i> or <img> */
  .hex-icon {
    font-size: calc(var(--hex-size) * 0.34);
    line-height: 1;
    color: #9fe0ff;                          /* tweak to taste */
  }
  .hex-inner img.hex-icon { width: calc(var(--hex-size) * 0.38); height: auto; }

  /* Hover affordance */
  .hex-outer:hover .hex-inner {
    transform: translateY(-4px);
    box-shadow:
      0 10px 24px rgba(0,0,0,.45),
      inset 0 0 0 1px rgba(255,255,255,0.12);
  }

  /* Responsive sizing */
  @media (max-width: 576px) { .hex-grid { --hex-size: 120px; } }
  @media (min-width: 1400px) { .hex-grid { --hex-size: 170px; } }




@media (min-width: 992px) {
    .software-skills .icon {
        font-size: 2.75rem;
    }
}

.software-skills .icon {
    font-size: 2.25rem;
    line-height: 1;
    display: inline-block;
}

/* Brand colors (single source of truth) */
.text-html5 {
    color: #e34f26;
}

.text-css3 {
    color: #1572b6;
}

.text-sass {
    color: #cc6699;
}

.text-js {
    color: #f7df1e;
}

.text-node {
    color: #339933;
}

.text-npm {
    color: #cb3837;
}

.text-yarn {
    color: #2c8ebc;
}

.text-flutter {
    color: #02569b;
}
.text-ubuntu {
    color: #E95420;
}
/* Ubuntu orange */
.text-nginx {
    color: #009639;
}
/* NGINX green */
.text-ssl {
    color: #10B981;
}
/* “A+” vibe, lock-check */
.text-database {
    color: #94A3B8;
}
/* neutral slate for generic DB */
.text-redis {
    color: #DC382D;
}
/* Redis red */
.text-windows {
    color: #0078D6;
}
/* Windows blue (proxy for WinForms) */
.text-csharp {
    color: #239120;
}
/* C# green */
.text-mssql {
    color: #CC2927;
}
/* SQL Server red */
.text-github {
    color: #ffffff;
}
/* use #181717 on light backgrounds */
.text-git {
    color: #F05032;
}

.text-dotnet {
    color: #512BD4;
}
/* .NET purple (also fine for ASP.NET MVC) */
.text-blazor {
    color: #512BD4;
}
/* keep consistent with .NET brand */
.text-devexpress {
    color: #FF7200;
}
/* DevExpress orange */
.text-dotnet {
    color: #512BD4;
}
/* ASP.NET Core/.NET */
.text-bootstrap {
    color: #7952B3;
}

.text-jwt {
    color: #F59E0B;
}
/* Simple Icons uses mono; keep it neutral */
/* put this AFTER Bootstrap */
.card-hv {
    position: relative;
    overflow: visible;
}

/* Desktop & devices that actually support hover */
@media (hover: hover) and (pointer: fine) and (min-width: 992px) {
    .card-hv .col-lg-3 {
        position: relative;
        isolation: isolate;
    }
        /* keeps zoom above neighbors */

        .card-hv .col-lg-3 img {
            display: block;
            float: none !important; /* kills .float-start without touching your markup */
            transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
            transform-origin: top left; /* grows outward, not over text */
            will-change: transform, box-shadow;
            z-index: 1;
        }

            .card-hv .col-lg-3 img:hover {
                transform: translate3d(6px,-6px,0) scale(2.8); /* tweak scale as you like */
                box-shadow: 0 .75rem 2rem rgba(0,0,0,.35);
                z-index: 20;
            }

    /* keep the whole card on top while interacting */
    .card-hv:hover {
        z-index: 5;
    }
}

/* Respect users who hate motion */
@media (prefers-reduced-motion: reduce) {
    .card-hv .col-lg-3 img {
        transition: none;
    }
}
