/* --- _colors.css --- */

/* Color Tokens 2D3340 037283*/
:root {
  --brand-primary: #2d3340;
  --brand-accent: #037283;
  --brand-secondary: #d5d5d5;
  --feedback-info: #0172b7;
  --feedback-success: #3d9f13;
  --feedback-warning: #b57f15;
  --feedback-danger: #b71a1b;
  --white: #ffffff;
  --black: #000000;
  --grey: #555555;
  --light: #ededed;
  --gray-100: #fdfdfd;
  --gray-200: #f5f5f5;
  --gray-300: #e5e5e5;
  --gray-400: #d5d5d5;
  --gray-500: #e7e7e7;
  --text-white: #ffffff;
  --text-black: #000000;
  --text-grey: #555555;
  --text-placeholder: #757575;
  --disabled-bg: #d7d7d7;
  --disabled-fg: #b9b9b9;
  --primary-500: #2d3340;
  --primary-400: #70747d;
  --primary-300: #9ea0a7;
  --primary-200: #bdbec3;
  --primary-100: #d2d3d6;
  --primary-600: #262b36;
  --primary-700: #20242d;
  --primary-800: #1b1e26;
  --primary-900: #171920;
  --accent-500: #037283;
  --accent-400: #549fab;
  --accent-300: #8bbec6;
  --accent-200: #b0d3d8;
  --accent-100: #c9e1e4;
  --accent-600: #03606e;
  --accent-700: #03515c;
  --accent-800: #03444d;
  --accent-900: #033941;
  --secondary-500: #d5d5d5;
  --secondary-400: #e2e2e2;
  --secondary-300: #ebebeb;
  --secondary-200: #f1f1f1;
  --secondary-100: #f5f5f5;
  --secondary-600: #b3b3b3;
  --secondary-700: #969696;
  --secondary-800: #7e7e7e;
  --secondary-900: #6a6a6a;
  --info-500: #0172b7;
  --info-400: #529fce;
  --info-300: #89bede;
  --info-200: #afd3e9;
  --info-100: #c9e1f0;
  --info-600: #01609a;
  --info-700: #015181;
  --info-800: #01446c;
  --info-900: #01395b;
  --success-500: #3d9f13;
  --success-400: #7bbe5f;
  --success-300: #a5d392;
  --success-200: #c2e1b5;
  --success-100: #d6ebcd;
  --success-600: #338610;
  --success-700: #2b710d;
  --success-800: #245f0b;
  --success-900: #1e5009;
  --warning-500: #b57f15;
  --warning-400: #cda860;
  --warning-300: #ddc493;
  --warning-200: #e8d7b6;
  --warning-100: #efe4cd;
  --warning-600: #986b12;
  --warning-700: #805a0f;
  --warning-800: #6c4c0d;
  --warning-900: #5b400b;
  --danger-500: #b71a1b;
  --danger-400: #ce6364;
  --danger-300: #de9596;
  --danger-200: #e9b7b8;
  --danger-100: #f0cecf;
  --danger-600: #9a1617;
  --danger-700: #811213;
  --danger-800: #6c0f10;
  --danger-900: #5b0d0d;
}

/* --- _shared.css --- */

/*--------------------------------------
Shared styles for the entire application
Example: utility classes, global resets, etc.
--------------------------------------*/

/* Composer */


/* Border Radius */
.br-full {
    border-radius: 9999px !important;
}

.br-a {
    border-radius: 8px !important;
}

.br-b {
    border-radius: 6px !important;
}

.br-c {
    border-radius: 4px !important;
}

.br-d {
    border-radius: 2px !important;
}

.br-null {
    border-radius: 0 !important;
}

/* Cursor */
.cursor-pointer {
    cursor: pointer;
}

.cursor-disabled {
    cursor: not-allowed;
}

/* Drop Shadow */
.shadow {
    box-shadow: 0px 0px 5px 1px rgba(150, 150, 150, 0.25);
    -webkit-box-shadow: 0px 0px 5px 1px rgba(150, 150, 150, 0.25);
    -moz-box-shadow: 0px 0px 5px 1px rgba(150, 150, 150, 0.25);
}

/* Wrappers */
.wrapper-column {
    display: flex;
    align-items: flex-start;
    align-self: stretch;
}

.bg-white {
    background: var(--white);
}

.wrapper-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-self: stretch;
}

.wrapper-wrap {
    display: flex;
    align-items: flex-start;
    align-content: flex-start;
    align-self: stretch;
    flex-wrap: wrap;
}

.w-full {
    flex: 1 0 0 !important;
}

/* Modifiers */
.gap-full {
    gap: 16px;
}

.gap-a {
    gap: 8px;
}

.gap-b {
    gap: 4px;
}

.gap-c {
    gap: 2px;
}

.gap-d {
    gap: 1px;
}

.p-a {
    padding: 8px;
}

.p-b {
    padding: 4px;
}

.p-c {
    padding: 2px;
}

.py-full {
    padding-top: 16px;
    padding-bottom: 16px;
}

.py-a {
    padding-top: 8px;
    padding-bottom: 8px;
}

.py-b {
    padding-top: 4px;
    padding-bottom: 4px;
}

.py-c {
    padding-top: 2px;
    padding-bottom: 2px;
}

.px-full {
    padding-left: 16px;
    padding-right: 16px;
}

.px-a {
    padding-left: 8px;
    padding-right: 8px;
}

.px-b {
    padding-left: 4px;
    padding-right: 4px;
}

.px-c {
    padding-left: 2px;
    padding-right: 2px;
}

.content-center {
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

/* Tooltip */
.tooltip {
    position: absolute;
    z-index: 9999;
    max-width: 260px;

    padding: 4px 8px;
    font-size: 12px;
    line-height: 18px;
    font-weight: 500;

    background: rgba(0, 0, 0, 0.88);
    color: #fff;
    border-radius: 4px;

    opacity: 0;
    transform: translateY(-4px);
    pointer-events: none;

    transition:
        opacity 500ms ease,
        transform 500ms ease;
}

.tooltip.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Avatar */
.avatar-sm {
	width: 22px;
	height: 22px;
	object-fit: cover;
	border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
    .tooltip {
        transition: none;
    }
}

/* --- _layout.css --- */

html,
body {
  margin: 0;
  padding: 0;
  background: var(--light);
  font-family: "Open Sans", sans-serif !important;
}

.site-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  grid-template-rows: auto 1fr;
  grid-template-areas:
    "sidebar header"
    "sidebar content";
  min-height: 100vh;
}

.stream {
  display: grid;
  max-width: 1440px;
  margin: 0 auto;
  gap: 16px;
  min-height: 100vh;
  grid-template-columns: 1fr minmax(280px, 360px);
  grid-template-areas: "feed widgets";
}

.stream .feed {
  grid-area: feed;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.widgets {
  grid-area: widgets;
  display: flex;
  flex-direction: column;
  gap: 16px;
}


.site-sidebar {
  margin: 0;
  grid-area: sidebar;
  display: flex;
  max-width: 280px;
  padding: 8px;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  align-self: stretch;
  background: var(--brand-primary);
}

.site-header {
  grid-area: header;
  display: flex !important;
  padding: 8px;
  align-items: flex-start;
  gap: 8px;
  align-self: stretch;
  background: var(--white);
}

.site-content {
  grid-area: content;
  padding: 16px;
}

.site-header,
.site-content {
  min-width: 0;
}

@media (max-width: 1120px) {
  .site-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    grid-template-areas:
      "header"
      "content"
      "sidebar";
  }

  .site-sidebar {
    display: none
  }
}

@media (max-width: 728px) {
  .site-content {
    padding: 8px;
  }
}

/* --- _typography.css --- */



/* --- _icons.css --- */

.icon-sqr {
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
	aspect-ratio: 1/1;
}

.icon-sm {
    font-weight: 400 !important;
    width: 18px !important;
    height: 18px !important;
    font-size: 14px;
}

.icon-rg {
    font-weight: 500 !important;
    width: 22px !important;
    height: 22px !important;
    font-size: 18px;
}

.icon-lg {
    font-weight: 600 !important;
    width: 24px !important;
    height: 24px !important;
    font-size: 22px;
}

/* --- _buttons.css --- */

.btn {
    all: unset;
    cursor: pointer !important;
    display: inline-flex;
    padding: 8px 16px;
    align-items: flex-start;
    font-weight: 500;
    gap: 8px;
    font-size: 14px;
    line-height: 22px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.32), inset 0 -1px 0 rgba(0, 0, 0, 0.08);
    user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    transition: background 0.3s ease, color 0.3s ease, box-shadow 0.6s ease;
}

.btn:hover {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.48), inset 0 -1px 0 rgba(0, 0, 0, 0.16);
}

.btn.disabled,
.btn:disabled,
.btn[disabled] {
    background: var(--disabled-bg);
    color: var(--disabled-fg);
    cursor: not-allowed !important;
    pointer-events: none;
}

.btn-icon {
    padding: 8px !important;
}

.btn-primary {
    background: var(--primary-500);
    color: var(--text-white);
}

.btn-primary:hover {
    background: var(--primary-700);
    color: var(--text-white);
}

.btn-accent {
    background: var(--accent-500);
    color: var(--text-white);
}

.btn-accent:hover {
    background: var(--accent-700);
    color: var(--text-white);
}

.btn-secondary {
    background: var(--secondary-500);
    color: var(--text-grey);
}

.btn-secondary:hover {
    background: var(--secondary-700);
    color: var(--text-black);
}

.btn-ghost {
    color: var(--text-grey);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0), inset 0 -1px 0 rgba(0, 0, 0, 0);
}

.btn-ghost:hover {
    background: var(--secondary-200);
    color: var(--text-black);
}


/* Feedback Buttons */
.btn-info {
    background: var(--info-500);
    color: var(--text-white);
}

.btn-info:hover {
    background: var(--info-700);
    color: var(--text-white);
}
.btn-success {
    background: var(--success-500);
    color: var(--text-white);
}

.btn-success:hover {
    background: var(--success-700);
    color: var(--text-white);
}

.btn-warning {
    background: var(--warning-500);
    color: var(--text-white);
}

.btn-warning:hover {
    background: var(--warning-700);
    color: var(--text-white);
}

.btn-danger {
    background: var(--danger-500);
    color: var(--text-white);
}

.btn-danger:hover {
    background: var(--danger-700);
    color: var(--text-white);
}

.btn-full {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex: 1 0 0;
    align-self: stretch;
}

/* --- _forms.css --- */

.space-filter-field {
    position: relative;
    width: 100%;
}

.space-filter-icon {
    position: absolute;
    top: 50%;
    left: 8px;
    transform: translateY(-50%);
    color: var(--primary-400);
    pointer-events: none;
    transition: color 0.3s;
}

.space-filter-input {
    display: block;
    padding: 7px 38px 7px 38px;
    background: var(--primary-700);
    border: 1px solid var(--primary-700);
    font-family: inherit;
    font-size: 14px;
    line-height: 22px;
    color: var(--primary-400);
    outline: none;
    transition: border-color 0.3s, background 0.3s, outline 0.3s;
}

.space-filter-field:focus-within .space-filter-icon {
    color: var(--white);
}

.space-filter-input:hover {
    border-color: var(--accent-500);
}

.space-filter-input:focus {
    color: var(--white);
    background: var(--primary-500);
    border-color: var(--accent-500);
    outline: 2px solid color-mix(in srgb, var(--accent-500) 32%, transparent);
}

/* Search Field */
.search-field {
    display: flex;
    position: relative;
    width: 100%;
}

.search-icon {
    position: absolute;
    top: 50%;
    left: 8px;
    transform: translateY(-50%);
    color: var(--text-placeholder);
    pointer-events: none;
    transition: color 0.3s;
}

.search-input {
    flex: 1 0 0;
    display: block;
    padding: 7px 38px 7px 38px;
    background: var(--gray-100);
    border: 1px solid var(--gray-500);
    font-family: inherit;
    font-size: 14px;
    line-height: 22px;
    color: var(--text-placeholder);
    outline: none;
    transition: border-color 0.3s, background 0.3s, outline 0.3s;
}

.search-field:focus-within .search-icon {
    color: var(--black);
}

.search-input:hover {
    border-color: var(--accent-500);
}

.search-input:focus {
    color: var(--black);
    background: var(--white);
    border-color: var(--accent-500);
    outline: 2px solid color-mix(in srgb, var(--accent-500) 32%, transparent);
}


/* --- _sidebar.css --- */

/*---------------------------
Sidebar styles
---------------------------*/

/* Main Navigation Block */

.brand-logo {
  cursor: pointer;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.nav-item {
  all: unset;
  cursor: pointer !important;
  color: var(--text-white);
  font-size: 14px;
  font-style: normal;
  line-height: 22px;
  display: flex;
  padding: 8px;
  align-items: center;
  gap: 8px;
  align-self: stretch;
  transition:
    background 0.3s ease,
    color 0.3s ease,
    box-shadow 0.3s ease;
}

.nav-item:hover {
  background: var(--primary-700);
  color: var(--text-white);
}

.nav-item.is-active {
  background: var(--primary-900);
  color: var(--text-white);
}

.space-category {
  display: flex;
  padding: 8px;
  align-items: center;
  gap: 8px;
  color: var(--primary-200);
  align-self: stretch;
}

.space-category a {
  text-decoration: none;
  padding: 0;
  margin: 0;
  display: flex;
  color: inherit;
  cursor: pointer !important;
  transition: color 0.3s ease;
}

.space-category > a > span {
  text-decoration: none;
  padding: 0;
  margin: 0;
  color: inherit;
  font-size: 14px;
  font-weight: 600;
  font-style: normal;
  line-height: 22px;
  flex: 1;
  text-transform: uppercase;
}

.space-category-label {
  flex: 1;
}

.space-category a:hover {
  color: var(--primary-100);
}

/* --- _directory.css --- */

/*---------------------------
Directories Styling
Used in Peoples, Spaces,
and Marketplace directories
---------------------------*/


.directory-grid {
    width: 100%;
    max-width: 1440px;
    padding: 8px;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(264px, 1fr));
}

/* Query for mobile devices */
@media (max-width: 600px) {
    .dir-grid {
        gap: 8px !important;
        padding: 4px !important;
    }
}

/* --- _cards.css --- */

/*--------------------------------------
Cards Component Shared across:
- Space Cards
- People Cards
- Maretplace Cards
--------------------------------------*/

.card-wrapper {
    display: flex;
    padding: 8px;
    flex-direction: column;
    align-items: flex-start;
    flex: 1 0 0;
    border-radius: 8px;
    background: var(--white);
    animation: pop-in 0.4s ease both;
    animation-delay: calc((sibling-index() - 1) * 32ms);
    animation-fill-mode: backwards;
}

.card-wrapper .cover {
    display: flex;
    padding: 8px;
    justify-content: space-between;
    align-items: flex-end;
    align-self: stretch;
    border-radius: 6px;
}

.card-wrapper .cover .aside {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    flex: 1 0 0;
    align-self: stretch;
}

.card-wrapper .cover .aside span {
    padding: 0;
    margin: 0;
    cursor: pointer;
    display: flex;
    padding: 4px 8px;
    gap: 4px;
    align-items: center;
    gap: auto;
    border-radius: 32px;
    color: var(--grey);
    border: 1px solid var(--secondary-500);
    background: var(--white);
    font-size: 12px !important;
    font-style: normal;
    line-height: 18px !important;
}

.card-wrapper .cover img {
    cursor: pointer;
    width: 80px;
    height: 80px;
    aspect-ratio: 1/1;
    border-radius: 4px;
    background: var(--secondary-100);
    border: 2px solid var(--white);
}

.card-wrapper .cover .is-online {
    border: 2px solid var(--success-500) !important;
}

.card-wrapper .header {
    display: flex;
    padding: 8px;
    flex-direction: column;
    align-items: flex-start;
    align-self: stretch;
}

.card-wrapper .header a {
    text-decoration: none;
    padding: 0;
    margin: 0;
    cursor: pointer;
    align-self: stretch;
    color: #000;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 27px;
}

.card-wrapper .header p {
    padding: 0;
    margin: 0;
    pointer-events: none;
    align-self: stretch;
    color: var(--grey);
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22px;
}

.card-wrapper .body {
    display: flex;
    padding: 8px;
    flex-direction: column;
    align-items: flex-start;
    flex: 1 0 0;
    align-self: stretch;
}

.card-wrapper .body p {
    padding: 0;
    margin: 0;
    pointer-events: none;
    align-self: stretch;
    color: var(--grey);
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 22px;
}

.card-wrapper .topics {
    display: flex;
    padding: 8px;
    align-items: flex-start;
    align-content: flex-start;
    gap: 4px;
    align-self: stretch;
    flex-wrap: wrap;
}

.card-wrapper .topics a {
    text-decoration: none;
    cursor: pointer;
    display: flex;
    padding: 4px 8px;
    justify-content: center;
    align-items: center;
    gap: 4px;
    border-radius: 32px;
    text-transform: uppercase;
    background: var(--secondary-100);
    color: var(--grey);
    font-size: 10px;
    font-style: normal;
    font-weight: 600;
    line-height: 10px;
    transition: background 0.3s, color 0.3s;
}

.card-wrapper .topics a:hover {
    background: var(--secondary-500);
    color: var(--black);
}

.card-wrapper .footer {
    display: flex;
    padding: 8px;
    align-items: flex-end;
    gap: 8px;
    align-self: stretch;
}

/* Tags for Marketplace */
.card-wrapper .cover .aside .featured {
    color: var(--danger-500);
    border: 1px solid var(--danger-500);
    background: var(--secondary-100);
}
.card-wrapper .cover .aside .professional {
    color: var(--primary-500);
    border: 1px solid var(--primary-500);
    background: var(--secondary-100);
}
.card-wrapper .cover .aside .partner {
    color: var(--accent-500);
    border: 1px solid var(--accent-500);
    background: var(--secondary-100);
}
.card-wrapper .cover .aside .featured {
    color: var(--danger-500);
    border: 1px solid var(--danger-500);
    background: var(--secondary-100);
}

/* --- _wall-entry.css --- */

.wall-entry-wrapper {
    display: flex;
    min-width: 256px;
    padding: 8px;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
    border-radius: 8px;
    background: var(--white);
}

.wall-entry-wrapper .header {
    display: flex;
    padding: 8px;
    align-items: center;
    gap: 8px;
    align-self: stretch;
}

.wall-entry-wrapper .header .info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    flex: 1 0 0;
}

.wall-entry-wrapper .header .info h1 {
    margin: 0;
    padding: 0;
    all: unset;
    font-size: 14x;
    color: var(--text-black);
    font-weight: 600;
    line-height:22px;
    align-self: stretch;
    flex-wrap: wrap;
}

.wall-entry-wrapper .header .info .meta {
    display: flex;
    align-items: center;
    align-content: center;
    gap: 4px;
    align-self: stretch;
    flex-wrap: wrap;
}

.wall-entry-wrapper .header .info .meta i {
    color: var(--text-grey);
}

.wall-entry-wrapper .header .info .meta a {
    padding: 0;
    margin: 0;
    text-decoration: none;
    color: var(--accent-500);
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 18px;
    transition: color 0.2s ease;
}

.wall-entry-wrapper .header .info .meta a:hover {
    color: var(--accent-700);
}

.wall-entry-wrapper .header .info .meta span {
    cursor: default;
    color: var(--text-grey);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
}

.wall-entry-wrapper .topics {
    display: flex;
    padding: 8px;
    align-items: flex-start;
    align-content: flex-start;
    gap: 4px;
    align-self: stretch;
    flex-wrap: wrap;
}

.wall-entry-wrapper .body {
    display: flex;
    padding: 8px;
    align-items: center;
    gap: 8px;
    align-self: stretch;
}

.wall-entry-wrapper .actions {
    display: flex;
    padding: 8px;
    align-items: center;
    gap: 8px;
    align-self: stretch;
}

.wall-entry-wrapper .comments {
    display: flex;
    padding: 8px;
    align-items: center;
    gap: 8px;
    align-self: stretch;
}

/* --- _widgets.css --- */

.widget-wrapper {
    display: flex;
    padding: 8px;
    flex-direction: column;
    align-items: flex-start;
    align-self: stretch;
    border-radius: 8px;
    background: var(--white);
}

.widget-wrapper .header {
    display: flex;
    padding: 8px;
    align-items: center;
    gap: 8px;
    align-self: stretch;
}

.widget-wrapper .header .title {
}
