/*==================================
  FONT IMPORT
==================================*/
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;700&display=swap');

/*==================================
  ROOT VARIABLES
==================================*/
:root {
  --font-primary: 'Poppins', sans-serif;

  --color-border: #3a3b4d;
  --color-tab-border: #3a3b4d;
  --color-tab-hover: #AC2747;
  --color-tab-active: #AC2747;
  --color-background-primary: #11141d;
  --color-background-secondary: #181b27;
  --color-background-hover: #0d0f1a;
  --color-block: #1e2030;
  --color-block-hover: #262840;
  --color-bookmark-icon: #1a1d2e;
  --color-text-primary: #e8e9f0;
  --color-text-muted: #7b7d90;

  --gradient-border: linear-gradient(90deg, #F75050, #6C033D, #F75050);

  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 12px;
  --spacing-lg: 24px;
  --spacing-xl: 40px;

  --border-width: 1.5px;
  --border-radius: .375rem;
  --border-radius-sm: .275rem;
  --border-radius-lg: .5rem;

  --animation-duration: 3s;
  --transition-duration: 0.25s;

  --logo-size: 60px;

  --tab-border-width: 1.5px;
  --tab-border-radius: .375rem;
  --tab-backdrop-filter: blur(1px);

  --card-gap: 6px;
  --group-gap: 14px;
}

/*==================================
  BASE
==================================*/
* {
  font-family: var(--font-primary) !important;
}

#__next, body, html {
  background: radial-gradient(ellipse at 60% 0%, #1a1f35 0%, #090A0F 70%);
  background-color: transparent !important;
}

/*==================================
  TAB STYLES
==================================*/
#myTab {
  padding: var(--spacing-xs) 0;
  background: none;
  display: flex;
  justify-content: flex-start;
  gap: var(--spacing-lg);
}

button[id$='-tab'] {
  border-width: var(--tab-border-width);
  border-radius: var(--tab-border-radius);
  border-color: var(--color-tab-border);
  backdrop-filter: var(--tab-backdrop-filter);
  padding: 3px 14px;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: var(--color-text-muted);
  transition: border-color var(--transition-duration) ease,
              color var(--transition-duration) ease;
}

button[id$='-tab']:hover {
  border-color: var(--color-tab-hover);
  color: var(--color-text-primary);
}

button[id$='-tab'][aria-selected="true"] {
  border-color: var(--color-tab-active);
  color: var(--color-text-primary);
}

/*==================================
  SERVICE CARD
==================================*/
.service-card {
  position: relative;
  padding: 0.3rem;
  margin: 0;
  border-radius: var(--border-radius);
  background: transparent;
  border: var(--border-width) solid var(--color-border);
  overflow: visible;
  transition: border-color var(--transition-duration) ease;
}

.service-title-text {
  padding-top: 0.2rem;
  padding-bottom: 0.2rem;
}

.bg-theme-200\/50,
.flex-1.service-block {
  background-color: var(--color-block) !important;
  transition: background-color var(--transition-duration) ease;
}

.service-card:hover [class*="bg-theme-200/50"],
.service-card:hover .flex-1.service-block {
  background-color: var(--color-block-hover) !important;
}

/* animated gradient border on hover */
.service-card::before {
  content: '';
  position: absolute;
  inset: calc(-1 * var(--border-width));
  background: var(--gradient-border);
  z-index: -2;
  border-radius: var(--border-radius);
  background-size: 200% 100%;
  animation: wave var(--animation-duration) linear infinite;
  opacity: 0;
  transition: opacity var(--transition-duration) ease;
}

.service-card:hover::before {
  opacity: 1;
}

@keyframes wave {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

.service-card::after {
  content: '';
  position: absolute;
  inset: var(--border-width);
  background: var(--color-background-primary);
  border-radius: var(--border-radius-sm);
  z-index: -1;
  transition: background-color var(--transition-duration) ease;
}

.service-card:hover::after {
  background: var(--color-background-hover);
}

.service-card:hover {
  border-color: transparent;
}

/*==================================
  GROUP HEADER
==================================*/
.services-group-title {
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--color-text-muted) !important;
  margin-bottom: 6px !important;
  padding-left: 2px;
  opacity: 0.7;
}

.services-group {
  margin-bottom: var(--group-gap);
}

.services-list {
  display: flex;
  flex-direction: column;
  gap: var(--card-gap);
}

/*==================================
  BOOKMARKS
==================================*/
.flex.flex-col.mt-3.bookmark-list {
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--border-radius);
  padding: var(--spacing-md) var(--spacing-sm) 0 var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
  background: var(--color-background-secondary);
}

.bookmark-icon {
  background-color: var(--color-bookmark-icon) !important;
}

/*==================================
  LAYOUT — SHARED BASE
==================================*/
#layout-groups {
  --gap: var(--group-gap);
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap) !important;
}

/*==================================
  LAYOUT — HOME TAB
  Row 1: 4 groups (Personal x4 + Dev x1 offset)
  Actually: Personal(5 cards) + Dev&Auto(3 cards)
  → 2 columns, Personal wider
==================================*/
:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="HOME-tab"])) #layout-groups {
  --gap: var(--group-gap);
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="HOME-tab"])) #layout-groups > .services-group:nth-child(1) {
  flex: 2 1 340px !important;
  min-width: 280px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="HOME-tab"])) #layout-groups > .services-group:nth-child(2) {
  flex: 1 1 200px !important;
  min-width: 180px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="HOME-tab"])) #layout-groups > .services-group:nth-child(n+3) {
  display: none !important;
}

/*==================================
  LAYOUT — MEDIA TAB
  Media Frontend (2 cards) | Media Automation (4 cards)
  → side by side, automation slightly wider
==================================*/
:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="MEDIA-tab"])) #layout-groups {
  --gap: var(--group-gap);
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="MEDIA-tab"])) #layout-groups > .services-group:nth-child(1) {
  flex: 1 1 200px !important;
  min-width: 180px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="MEDIA-tab"])) #layout-groups > .services-group:nth-child(2) {
  flex: 2 1 340px !important;
  min-width: 280px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="MEDIA-tab"])) #layout-groups > .services-group:nth-child(n+3) {
  display: none !important;
}

/*==================================
  LAYOUT — INFRA TAB
  Row 1: Networking (2) | Monitoring (3)
  Row 2: Utilities (2) — full width or left-aligned
==================================*/
:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="INFRA-tab"])) #layout-groups {
  --gap: var(--group-gap);
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="INFRA-tab"])) #layout-groups > .services-group:nth-child(1) {
  flex: 1 1 200px !important;
  min-width: 180px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="INFRA-tab"])) #layout-groups > .services-group:nth-child(2) {
  flex: 2 1 320px !important;
  min-width: 260px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="INFRA-tab"])) #layout-groups > .services-group:nth-child(3) {
  flex: 1 1 200px !important;
  min-width: 180px;
}

:is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="INFRA-tab"])) #layout-groups > .services-group:nth-child(n+4) {
  display: none !important;
}

/*==================================
  TEXT
==================================*/
.text-sm {
  white-space: pre-line;
  text-align: center;
  font-size: 0.78rem;
  color: var(--color-text-muted);
}

/*==================================
  FOOTER
==================================*/
#footer {
  display: none;
}

/*==================================
  MOBILE — max-width: 768px
==================================*/
@media (max-width: 768px) {
  :root {
    --group-gap: 10px;
    --card-gap: 5px;
  }

  #myTab {
    gap: var(--spacing-md);
    flex-wrap: wrap;
  }

  button[id$='-tab'] {
    padding: 3px 10px;
    font-size: 0.75rem;
  }

  /* all tabs: single column stack on mobile */
  :is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="HOME-tab"])) #layout-groups > .services-group,
  :is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="MEDIA-tab"])) #layout-groups > .services-group,
  :is([id="inner_wrapper"]:has(#tabs [aria-selected="true"][id="INFRA-tab"])) #layout-groups > .services-group {
    flex: 1 1 100% !important;
    min-width: 0 !important;
    display: block !important;
  }

  .service-card {
    padding: 0.25rem;
  }

  .services-group-title {
    font-size: 0.6rem !important;
  }
}

/*==================================
  MOBILE — max-width: 480px
==================================*/
@media (max-width: 480px) {
  :root {
    --group-gap: 8px;
    --card-gap: 4px;
  }

  #myTab {
    gap: var(--spacing-sm);
  }

  button[id$='-tab'] {
    padding: 2px 8px;
    font-size: 0.7rem;
  }

  .text-sm {
    font-size: 0.7rem;
  }
}
