@charset "UTF-8";

/***** CSS Variables *****/
/* Purpose: Centralized design tokens for colors, typography, spacing, and component styling */
/* Usage: Use var(--variable-name) throughout the stylesheet for consistent theming */
/* Organization: Grouped by category (colors, typography, spacing, components, etc.) */

:root {
  /* ============================================
     BASE COLORS - Foundation Colors
     ============================================ */
  --color-black: #000;
  --color-white: #fff;

  /* ============================================
     BRAND COLORS - Primary Brand Identity
     ============================================ */
  --color-brand-primary: #FF4D5B;
  --color-brand-secondary: #FFCACC;
  --color-brand-tertiary: #FFE2E2;

  /* ============================================
     GRAYSCALE - Neutral Colors
     ============================================ */
  --color-gray-bg: #f3f3f3;
  --color-gray-medium: #999;
  --color-gray-dark: #222;

  /* ============================================
     BORDER COLORS - Border Styling
     ============================================ */
  /* Base border colors */
  --color-border-default: #E0E0E0;
  --color-border-dark: var(--color-gray-dark);
  --color-border-tag: #C2C8CC;
  --color-dropdown-border: #d8dcde;
  
  /* Semantic border tokens - Purpose-driven aliases */
  --color-border-subtle: var(--color-border-default);
  --color-border-primary: var(--color-border-dark);
  --color-border-focus: var(--focus-ring-color);

  /* ============================================
     TEXT COLORS - Typography Colors
     ============================================ */
  --color-text-dark: var(--color-gray-dark);
  --color-text-secondary: #666666;
  --color-text-medium: #49545C;
  --color-text-muted: var(--color-text-secondary);
  --color-text-light: #777;

  /* ============================================
     BACKGROUND COLORS - Background Styling
     ============================================ */
  --color-bg-hero: var(--color-brand-tertiary);
  --color-bg-body: #fffdfa;
  --color-bg-dark: #F7F5F0;

  /* ============================================
     ACCENT COLORS - Interactive Elements
     ============================================ */
  --color-accent-red: var(--color-brand-primary);
  --color-accent-red-hover: #CC3E49; /* 20% darker than --color-accent-red */
  --color-accent-blue: #158ec2;

  /* ============================================
     STATUS COLORS - Status Indicators
     ============================================ */
  --color-status-green: #038153;
  --color-status-blue: #1f73b7;
  --color-status-red: #c72a1c;
  --color-status-yellow: #ffb648;
  --color-status-yellow-text: #703b15;
  --color-status-teal: #04444d;

  /* ============================================
     NOTIFICATION COLORS - Alert/Notification Styling
     ============================================ */
  /* Error notification colors */
  --color-notification-error-bg: #fff0f1;
  --color-notification-error-border: #e35b66;
  --color-notification-error-text: #cc3340;
  /* Warning notification colors */
  --color-notification-warning-bg: #fff8ed;
  --color-notification-warning-border: #fcdba9;
  --color-notification-warning-text: #ad5e18;
  /* Info notification colors */
  --color-notification-info-bg: #dbf3ff;
  --color-notification-info-border: #b5e0f5;
  /* Success notification colors */
  --color-notification-success-bg: #ffeded;
  --color-notification-success-border: #f7cbcb;

  /* ============================================
     SHADOW COLORS - Shadow Effects
     ============================================ */
  --color-shadow-hover: rgba(31, 115, 183, 0.08);

  /* ============================================
     BORDER RADIUS - Corner Rounding
     ============================================ */
  --radius-sm: 2px;   /* Small elements, tags */
  --radius-md: 4px;   /* Default for buttons, inputs, cards */
  --radius-lg: 8px;   /* Larger elements, search fields */
  --radius-full: 50px; /* Circular elements like pills, icon buttons */

  /* ============================================
     TYPOGRAPHY SCALE - Font Sizes
     ============================================ */
  --font-size-sm: 0.75rem;    /* 12px - Small text, captions */
  --font-size-md: 0.875rem;   /* 14px - Secondary text */
  --font-size-base: 1rem;     /* 16px - Base size for body text and most UI elements */
  --font-size-lg: 1.125rem;    /* 18px - Emphasized text */
  --font-size-xl: 1.25rem;     /* 20px - Small headings */
  --font-size-2xl: 1.5rem;     /* 24px - Medium headings */
  --font-size-2xl-plus: 2rem;  /* 32px - Large medium headings */
  --font-size-3xl: 1.75rem;    /* 28px - Large headings */
  --font-size-4xl: 3rem;       /* 48px - Extra large headings */
  --font-size-5xl: 4rem;       /* 64px - Hero headings */

  /* ============================================
     LINE HEIGHTS - Text Spacing
     ============================================ */
  --line-height-null: 100%;    /* No extra spacing */
  --line-height-tight: 1.25;   /* Tight spacing for headings */
  --line-height-normal: 1.4;   /* Default for body text */
  --line-height-relaxed: 1.5;  /* Comfortable reading */

  /* ============================================
     Z-INDEX SCALE - Layer Stacking
     ============================================ */
  --z-index-base: 0;
  --z-index-sticky: 1;
  --z-index-fixed: 2;
  --z-index-modal-backdrop: 999;
  --z-index-dropdown: 1000;
  --z-index-modal: 1400;
  --z-index-popover: 1500;
  --z-index-tooltip: 1600;

  /* ============================================
     TRANSITIONS - Animation Timing
     ============================================ */
  --transition-fast: 100ms ease;
  --transition-base: 150ms ease;
  --transition-slow: 250ms ease;

  /* ============================================
     EASING FUNCTIONS - Animation Curves
     ============================================ */
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --ease: cubic-bezier(0.2, 0, 0, 1);

  /* ============================================
     SHADOW ELEVATION SYSTEM - Depth & Hierarchy
     ============================================ */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1);
  --shadow-md: 0px 1px 2px rgba(0, 0, 0, 0.08), 0px 4px 12px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 6px 16px rgba(0, 0, 0, 0.12);

  /* ============================================
     FOCUS STATES - Accessibility (WCAG Compliant)
     ============================================ */
  --focus-ring-width: 2px;
  --focus-ring-offset: 2px;
  --focus-ring-color: var(--color-accent-blue);
  --focus-ring: var(--focus-ring-width) solid var(--focus-ring-color);

  /* ============================================
     SEMANTIC TOKENS - Purpose-Driven Color Usage
     ============================================ */
  /* Text semantic tokens */
  --color-text-primary: var(--color-text-dark);

  /* ============================================
     COMPONENT TOKENS - Component-Specific Styling
     ============================================ */

  /* Button Component Tokens */
  /* Structural properties shared across all button variants */
  /* Variants define their own colors - see .button-primary, .button-secondary in Buttons section */
  --button-border-radius: var(--radius-md);
  --button-transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base);
  /* Button size tokens - Default size */
  --button-padding-x: var(--spacing-2);
  --button-padding-y: var(--spacing-1-5);
  --button-font-size: var(--font-size-base);
  --button-line-height: var(--line-height-normal);
  --button-min-width: auto;
  /* Icon button tokens - For icon-only buttons */
  --icon-button-size: 3rem;        /* 48px - Square icon button size */
  --icon-button-icon-size: 1.5rem; /* 24px - Icon size within button */

  /* Icon size tokens - General icon sizing (not just buttons) */
  --icon-size-small: 1rem;    /* 16px - Small icons */
  --icon-size-medium: 1.5rem; /* 24px - Medium icons (default) */ 

  /* Input/Form Component Tokens */
  --input-padding-x: var(--spacing-1-5);
  --input-padding-y: var(--spacing-1);
  --input-border-radius: var(--radius-md);
  --input-border-width: 1px;
  --input-border-width-focus: 2px;
  --input-border-color: var(--color-border-default);
  --input-border-color-focus: var(--color-border-focus);
  --input-font-size: var(--font-size-base);

  /* Card Component Tokens */
  --card-padding: var(--spacing-3);
  --card-border-radius: var(--radius-lg);
  --card-shadow: var(--shadow-md);
  --card-bg: var(--color-white);

  /* ============================================
     LAYOUT TOKENS - Container Widths
     ============================================ */
  --container-max-width: 90rem;           /* 1440px - Total width including padding */
  --container-content-max-width: 72.5rem; /* 1160px - Legacy container width */
  --search-max-width: 40.5rem;          /* 648px - Search input max width */

  /* ============================================
     SPACING SCALE - 8px Base Grid System
     ============================================ */
  --spacing-0: 0;
  --spacing-0-5: 0.25rem;  /* 4px - Tight spacing */
  --spacing-1: 0.5rem;     /* 8px - Base unit */
  --spacing-1-5: 0.75rem;  /* 12px - 1.5x base */
  --spacing-2: 1rem;       /* 16px - 2x base (common) */
  --spacing-3: 1.5rem;     /* 24px - 3x base (common) */
  --spacing-4: 2rem;       /* 32px - 4x base */
  --spacing-5: 2.5rem;     /* 40px - 5x base */
  --spacing-6: 3rem;       /* 48px - 6x base (common) */
  --spacing-7: 6rem;       /* 96px - 7x base */
}

/***** Normalize.css *****/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  font-size: var(--font-size-base); /* Base font size - 1rem = 16px */
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
  font-feature-settings: inherit;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,;
[type=button]::-moz-focus-inner,;
[type=reset]::-moz-focus-inner,;
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,;
[type=button]:-moz-focusring,;
[type=reset]:-moz-focusring,;
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,;
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

/***** Fonts *****/

@font-face {
  font-family: "Wulkan";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local(""), url("https://cdn.ostrich.co.uk/fonts/wulkan-headline-medium.woff2") format("woff2"), url("https://media.ostrich.co.uk/fonts/wulkan-headline-medium.woff") format("woff");
}

@font-face {
  font-family: Wulcan;
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: local(""), url("https://cdn.ostrich.co.uk/fonts/wulkan-headline-medium-italic.woff2") format("woff2"), url("https://cdn.ostrich.co.uk/fonts/wulkan-headline-medium-italic.woff") format("woff");
}

@font-face {
  font-family: "Moderat";
  font-style: normal;
  font-weight: 450;
  font-display: swap;
  src: local(""), url("https://media.ostrich.co.uk/fonts/Moderat-Book.woff2") format("woff2"), url("https://media.ostrich.co.uk/fonts/Moderat-Book.woff") format("woff");
}

@font-face {
  font-family: "Moderat";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local(""), url("https://media.ostrich.co.uk/fonts/Moderat-Medium.woff2") format("woff2"), url("https://media.ostrich.co.uk/fonts/Moderat-Medium.woff") format("woff");
}

@font-face {
  font-family: "Moderat";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: local(""), url("https://media.ostrich.co.uk/fonts/Moderat-Semibold.woff2") format("woff2"), url("https://media.ostrich.co.uk/fonts/Moderat-Semibold.woff") format("woff");
}

/***** Base *****/

* {
  box-sizing: border-box;
}

body {
  background-color: rgba(255, 253, 250, 1);
  color: rgba(34, 34, 34, 1);
  font-family: "Moderat", 'Helvetica Neue', Arial, Helvetica, sans-serif;
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  font-feature-settings: 'ss03' on, 'ss04' on, 'ss06' on, 'ss08' on, 'liga' off;
  -webkit-font-smoothing: antialiased;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  body > main {
    min-height: 65vh;
  }
}

h1 {
  font-family: "Wulkan", serif;
  line-height: var(--line-height-tight);
  margin:0;
}

h2,
h3,
h4,
h5,
h6 {
  font-family: "Moderat", serif;
  line-height: var(--line-height-tight);
  margin:0;
}

/* Ensure all headings inside article body use Moderat */
.article-body h1,
.article-body h2,
.article-body h3,
.article-body h4,
.article-body h5,
.article-body h6 {
  font-family: "Moderat", 'Helvetica Neue', Arial, Helvetica, sans-serif;
}

/* Article body heading size hierarchy (below 40px page title) */
.article-body h2 {
  font-size: var(--font-size-2xl);
  font-weight: 600;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .article-body h2 {
    font-size: var(--font-size-2xl-plus);
  }
}

h1 {
  font-size: var(--font-size-5xl);
}

/* Internal page titles (exclude homepage hero which uses h2) */
.page-header h1,
.article-header h1,
.post-title h1,
.request-title h1 {
  font-family: "Moderat", 'Helvetica Neue', Arial, Helvetica, sans-serif;
  font-size: var(--font-size-2xl-plus);
  letter-spacing: -1.1px;
}

@media (min-width: 768px) {
  .page-header h1,
  .article-header h1,
  .post-title h1,
  .request-title h1 {
    font-size: 2.5rem; /* 40px */
  }
}

h2 {
  font-size: var(--font-size-4xl); /* 48px - mobile default */
  font-weight: 500;
  letter-spacing: -1.28px;
}

@media (min-width: 768px) {
  h2 {
    font-size: var(--font-size-5xl); /* 64px - desktop */
  }
}

h3 {
  font-size: var(--font-size-xl);
  font-weight: 600;
  padding-top: --var(--spacing-3);
}
@media (min-width: 768px) {
  h3 {
    font-size: var(--font-size-2xl);
  }
}

h4 {
  font-size: var(--font-size-xl);
}
@media (min-width: 768px) {
  h4 {
    font-size: var(--font-size-lg); 
  }
}

a {
  color: rgba(34, 34, 34, 1);
  text-decoration: none;
}
a:visited {
  color: rgba(0, 0, 0, 1);
}
a:hover, a:active, a:focus {
  text-decoration: underline;
}

input,
textarea {
  color: var(--color-black);
  font-size: var(--font-size-base);
}

input {
  max-width: 100%;
  box-sizing: border-box;
  transition: border var(--transition-base) var(--ease-out);
}
input:not([type=checkbox]) {
  outline: none;
}
input:not([type=checkbox]):focus {
  border: var(--input-border-width) solid var(--input-border-color-focus);
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

input[disabled] {
  background-color: var(--color-border-default);
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  background: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23CCC' d='M0 0h10L5 6 0 0z'/%3E%3C/svg%3E%0A") no-repeat var(--color-white);
  background-position: right var(--input-padding-x) center;
  border: var(--input-border-width) solid var(--input-border-color);
  border-radius: var(--input-border-radius);
  padding: var(--input-padding-y) 30px var(--input-padding-y) var(--input-padding-x);
  outline: none;
  color: var(--color-gray-dark);
  width: 100%;
  font-size: var(--input-font-size);
}
select:focus {
  border: var(--input-border-width) solid var(--input-border-color-focus);
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}
select::-ms-expand {
  display: none;
}

textarea {
  border: var(--input-border-width) solid var(--input-border-color);
  border-radius: var(--input-border-radius);
  resize: vertical;
  width: 100%;
  outline: none;
  padding: var(--input-padding-y) var(--input-padding-x);
  font-size: var(--input-font-size);
}
textarea:focus {
  border: var(--input-border-width) solid var(--input-border-color-focus);
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

/***** Layout Components *****/
/* Container pattern - shared responsive container with consistent padding and max-width */
/* Mobile: Full width with 24px (1.5rem) horizontal padding */
/* Desktop (768px+): Max width 1440px with 48px (3rem) horizontal padding */
.container {
  margin: 0 auto;
  padding: 0 var(--spacing-3); /* 24px on mobile */
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .container {
    max-width: var(--container-max-width); /* 1440px - includes padding */
    padding: 0 var(--spacing-6); /* 48px on each side */
  }
}

.container-divider {
  margin-bottom: var(--spacing-3);
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.error-page {
  max-width: var(--container-content-max-width);
  margin: 0 auto;
  padding: 0 5%;
}
@media (min-width: 1440px) { /* --breakpoint-lg */
  .error-page {
    padding: 0;
    width: 90%;
  }
}

/***** Utility Classes *****/
/* Screen reader only / visually hidden utility */
/* Purpose: Hide content visually while keeping it accessible to screen readers */
/* Usage: Apply to elements that should be hidden visually but remain in the DOM for accessibility */
.visibility-hidden,
.recent-activity-accessibility-label,
.pagination-first-text,
.pagination-last-text {
  border: 0;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}

/***** Buttons *****/
/* Purpose: All button styles including base, variants, sizes, and context-specific buttons */
/* Usage: Apply .button class with variant (.button-primary, .button-secondary) and optional size (.button-large) */
/* Architecture: Uses CSS variables for theming - variants set color variables, base sets structural properties */

/* Base Button Styles - Common properties for all button types */
/* Applies to: standard buttons, pagination links, subscription buttons, split buttons */
.button,
.pagination-next-link,
.pagination-prev-link,
.pagination-first-link,
.pagination-last-link,
.subscriptions-subscribe button,
.requests-table-toolbar .organization-subscribe button,
.community-follow button,
.article-subscribe button,
.section-subscribe button,
.split-button button {
  /* Structural properties */
  background-color: var(--button-bg, transparent);
  border: 1px solid var(--button-border-color, rgba(34, 34, 34, 1));
  border-radius: var(--button-border-radius);
  color: var(--button-color, rgba(34, 34, 34, 1));
  cursor: pointer;
  display: inline-block;
  font-size: var(--button-font-size);
  font-weight: 600;
  line-height: var(--button-line-height);
  margin: 0;
  padding: var(--button-padding-y) var(--button-padding-x);
  min-width: 128px;
  text-align: center;
  transition: var(--button-transition);
  user-select: none;
  white-space: nowrap;
  width: 100%;
  -webkit-touch-callout: none;
}

/* Responsive: Full width on mobile, auto width on desktop */
@media (min-width: 768px) { /* --breakpoint-sm */
  .button,
  .pagination-next-link,
  .pagination-prev-link,
  .pagination-first-link,
  .pagination-last-link,
  .subscriptions-subscribe button,
  .requests-table-toolbar .organization-subscribe button,
  .community-follow button,
  .article-subscribe button,
  .section-subscribe button,
  .split-button button {
    width: auto;
  }
}

/* Button :visited state - maintains color from variant */
.button:visited,
.pagination-next-link:visited,
.pagination-prev-link:visited,
.pagination-first-link:visited,
.pagination-last-link:visited,
.subscriptions-subscribe button:visited,
.requests-table-toolbar .organization-subscribe button:visited,
.community-follow button:visited,
.article-subscribe button:visited,
.section-subscribe button:visited,
.split-button button:visited {
  color: var(--button-color, rgba(34, 34, 34, 1));
}

/* Button Interactive States (hover, active, focus) - Uses variant hover variables */
.button:hover,
.button:active,
.button:focus,
.pagination-next-link:hover,
.pagination-next-link:active,
.pagination-next-link:focus,
.pagination-prev-link:hover,
.pagination-prev-link:active,
.pagination-prev-link:focus,
.pagination-first-link:hover,
.pagination-first-link:active,
.pagination-first-link:focus,
.pagination-last-link:hover,
.pagination-last-link:active,
.pagination-last-link:focus,
.subscriptions-subscribe button:hover,
.subscriptions-subscribe button:active,
.subscriptions-subscribe button:focus,
.requests-table-toolbar .organization-subscribe button:hover,
.requests-table-toolbar .organization-subscribe button:active,
.requests-table-toolbar .organization-subscribe button:focus,
.community-follow button:hover,
.community-follow button:active,
.community-follow button:focus,
.article-subscribe button:hover,
.article-subscribe button:active,
.article-subscribe button:focus,
.section-subscribe button:hover,
.section-subscribe button:active,
.section-subscribe button:focus,
.split-button button:hover,
.split-button button:active,
.split-button button:focus {
  background-color: var(--button-bg-hover, rgba(34, 34, 34, 1));
  color: var(--button-color-hover, rgba(255, 255, 255, 1));
  border-color: var(--button-border-color-hover, rgba(34, 34, 34, 1));
  text-decoration: none;
}

/* Button Variant - Primary */
/* Dark background with white text - used for primary actions */
/* Applies to: .button-primary class and selected subscription buttons */
.button.button-primary,
.button-primary.pagination-next-link,
.button-primary.pagination-prev-link,
.button-primary.pagination-first-link,
.button-primary.pagination-last-link,
.subscriptions-subscribe button.button-primary,
.subscriptions-subscribe button[data-selected=true],
.requests-table-toolbar .organization-subscribe button.button-primary,
.requests-table-toolbar .organization-subscribe button[data-selected=true],
.community-follow button.button-primary,
.article-subscribe button.button-primary,
.article-subscribe button[data-selected=true],
.section-subscribe button.button-primary,
.section-subscribe button[data-selected=true],
.split-button button.button-primary {
  --button-bg: var(--color-gray-dark);
  --button-color: var(--color-white);
  --button-border-color: var(--color-gray-dark);
  --button-bg-hover: var(--color-black);
  --button-color-hover: var(--color-white);
  --button-border-color-hover: var(--color-black);
}

/* Primary button hover/active/focus states - ensures hover variables are applied */
.button.button-primary:hover,
.button.button-primary:active,
.button.button-primary:focus,
.button-primary.pagination-next-link:hover,
.button-primary.pagination-next-link:active,
.button-primary.pagination-next-link:focus,
.button-primary.pagination-prev-link:hover,
.button-primary.pagination-prev-link:active,
.button-primary.pagination-prev-link:focus,
.button-primary.pagination-first-link:hover,
.button-primary.pagination-first-link:active,
.button-primary.pagination-first-link:focus,
.button-primary.pagination-last-link:hover,
.button-primary.pagination-last-link:active,
.button-primary.pagination-last-link:focus,
.subscriptions-subscribe button.button-primary:hover,
.subscriptions-subscribe button.button-primary:active,
.subscriptions-subscribe button.button-primary:focus,
.subscriptions-subscribe button[data-selected=true]:hover,
.subscriptions-subscribe button[data-selected=true]:active,
.subscriptions-subscribe button[data-selected=true]:focus,
.requests-table-toolbar .organization-subscribe button.button-primary:hover,
.requests-table-toolbar .organization-subscribe button.button-primary:active,
.requests-table-toolbar .organization-subscribe button.button-primary:focus,
.requests-table-toolbar .organization-subscribe button[data-selected=true]:hover,
.requests-table-toolbar .organization-subscribe button[data-selected=true]:active,
.requests-table-toolbar .organization-subscribe button[data-selected=true]:focus,
.community-follow button.button-primary:hover,
.community-follow button.button-primary:active,
.community-follow button.button-primary:focus,
.article-subscribe button.button-primary:hover,
.article-subscribe button.button-primary:active,
.article-subscribe button.button-primary:focus,
.article-subscribe button[data-selected=true]:hover,
.article-subscribe button[data-selected=true]:active,
.article-subscribe button[data-selected=true]:focus,
.section-subscribe button.button-primary:hover,
.section-subscribe button.button-primary:active,
.section-subscribe button.button-primary:focus,
.section-subscribe button[data-selected=true]:hover,
.section-subscribe button[data-selected=true]:active,
.section-subscribe button[data-selected=true]:focus,
.split-button button.button-primary:hover,
.split-button button.button-primary:active,
.split-button button.button-primary:focus {
  background-color: var(--button-bg-hover, var(--color-gray-dark));
  color: var(--button-color-hover, var(--color-white));
  border-color: var(--button-border-color-hover, var(--color-gray-dark));
}
/* Button Disabled State - Prevents interaction */
.button[data-disabled],
[data-disabled].pagination-next-link,
[data-disabled].pagination-prev-link,
[data-disabled].pagination-first-link,
[data-disabled].pagination-last-link,
.subscriptions-subscribe button[data-disabled],
.requests-table-toolbar .organization-subscribe button[data-disabled],
.community-follow button[data-disabled],
.article-subscribe button[data-disabled],
.section-subscribe button[data-disabled],
.split-button button[data-disabled] {
  cursor: default;
}

/* Button Variant - Secondary */
/* Transparent background with dark border and text - used for secondary actions */
/* Also applied to pagination controls by default */
.button-secondary,
.pagination-next-link,
.pagination-prev-link,
.pagination-first-link,
.pagination-last-link {
  --button-bg: transparent;
  --button-color: var(--color-gray-dark);
  --button-border-color: var(--color-gray-dark);
  --button-bg-hover: var(--color-bg-dark);
  --button-color-hover: var(--color-gray-dark);
  --button-border-color-hover: var(--color-black);
}

/* Secondary button :visited state */
.button-secondary:visited {
  color: var(--button-color, var(--color-gray-dark));
}

/* Secondary button hover/active/focus states */
.button-secondary:hover,
.button-secondary:active,
.button-secondary:focus,
.pagination-next-link:hover,
.pagination-next-link:active,
.pagination-next-link:focus,
.pagination-prev-link:hover,
.pagination-prev-link:active,
.pagination-prev-link:focus,
.pagination-first-link:hover,
.pagination-first-link:active,
.pagination-first-link:focus,
.pagination-last-link:hover,
.pagination-last-link:active,
.pagination-last-link:focus {
  background-color: var(--button-bg-hover, transparent);
  color: var(--button-color-hover, var(--color-gray-dark));
  border-color: var(--button-border-color-hover, var(--color-gray-dark));
}

/* Button Size Modifier - Large */
/* Increases padding and line-height for larger buttons */
/* Can be combined with any variant: .button-primary.button-large */
.button-large {
  --button-padding-x: 1.9286em;
  --button-padding-y: 0;
  --button-line-height: 2.72;
  --button-min-width: 11.875rem; /* 190px */
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .button-large {
    width: auto;
  }
}

/* Input Submit Buttons - Default to primary variant with large size */
/* Used for form submission buttons */
input[type=submit] {
  --button-padding-x: 1.9286em;
  --button-padding-y: 0;
  --button-line-height: 2.72;
  --button-min-width: 11.875rem; /* 190px */
  --button-bg: rgba(34, 34, 34, 1);
  --button-color: rgba(255, 255, 255, 1);
  --button-border-color: transparent;
  --button-bg-hover: #000;
  --button-color-hover: rgba(255, 255, 255, 1);
  --button-border-color-hover: transparent;
  border: 0;
}

@media (min-width: 768px) { /* --breakpoint-sm */
  input[type=submit] {
    width: auto;
  }
}

input[type=submit]:visited {
  color: var(--button-color, rgba(255, 255, 255, 1));
}

input[type=submit][disabled] {
  background-color: var(--color-border-default);
}

/***** Split Button Component *****/
/* Purpose: Button group with main action and dropdown trigger */
/* Usage: Used for actions with multiple options */

.split-button {
  display: flex;
}

/* Split button inherits base button styles but overrides some properties */
.split-button button {
  background-color: rgba(34, 34, 34, 1);
  border: 0;
  color: rgba(255, 255, 255, 1);
  height: var(--spacing-4); /* 32px */
  line-height: var(--font-size-base); /* 16px */
  outline-color: rgba(34, 34, 34, 1);
}

[dir=rtl] .split-button button:not(:only-child):first-child {
  border-left: 1px solid rgba(255, 255, 255, 1);
  border-top-left-radius: unset;
  border-bottom-left-radius: unset;
}
[dir=ltr] .split-button button:not(:only-child):first-child {
  border-right: 1px solid rgba(255, 255, 255, 1);
  border-top-right-radius: unset;
  border-bottom-right-radius: unset;
}
.split-button button:not(:only-child):last-child {
  display: flex;
  justify-content: center;
  align-items: center;
  width: var(--spacing-3); /*24px*/
  min-width: var(--spacing-3); /*24px*/
  max-width: var(--spacing-3); /*24px*/
  padding: 0;
}
[dir=rtl] .split-button button:not(:only-child):last-child {
  border-top-right-radius: unset;
  border-bottom-right-radius: unset;
}
[dir=ltr] .split-button button:not(:only-child):last-child {
  border-top-left-radius: unset;
  border-bottom-left-radius: unset;
}

/***** Tables *****/
.table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  border-spacing: 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .table {
    table-layout: auto;
  }
}
.table th,
.table th a {
  color: #555;
  font-size: var(--font-size-base);
  text-align: left;
}
[dir=rtl] .table th,
[dir=rtl] .table th a {
  text-align: right;
}
.table tr {
  border-bottom: 1px solid var(--color-border-default);
  display: block;
  padding: var(--spacing-3) 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .table tr {
    display: table-row;
  }
}
.table td {
  display: block;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .table td {
    display: table-cell;
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .table td, .table th {
    padding: var(--spacing-3) 1.875rem; /* 30px - using rem for accessibility */
  }
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .table td, .table th {
    padding: var(--spacing-1-5) var(--spacing-3);
    height: 4rem; /*64px*/
  }
}

/***** Forms *****/
.form {
  max-width: var(--form-max-width);
}

.form-field ~ .form-field {
  margin-top: var(--spacing-3);
}

.form-field label {
  display: block;
  font-size: var(--font-size-base);
  margin-bottom: var(--spacing-0-5);
}

.form-field input {
  border: var(--input-border-width) solid var(--input-border-color);
  border-radius: var(--input-border-radius);
  padding: var(--input-padding-y) var(--input-padding-x);
  width: 100%;
  font-size: var(--input-font-size);
}
.form-field input:focus {
  border: var(--input-border-width) solid var(--input-border-color-focus);
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

.form-field input[type=text] {
  border: var(--input-border-width) solid var(--input-border-color);
  border-radius: var(--input-border-radius);
}
.form-field input[type=text]:focus {
  border: var(--input-border-width) solid var(--input-border-color-focus);
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

.form-field input[type=checkbox] {
  width: auto;
}

.form-field .nesty-input {
  border-radius: var(--input-border-radius);
  border: var(--input-border-width) solid var(--input-border-color);
  height: 2.5rem; /* 40px */
  line-height: var(--line-height-normal);
  outline: none;
  vertical-align: middle;
  font-size: var(--input-font-size);
}

.form-field .nesty-input:focus {
  border: var(--input-border-width) solid var(--input-border-color-focus);
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
  text-decoration: none;
}

.form-field .hc-multiselect-toggle {
  border: var(--input-border-width) solid var(--input-border-color);
  border-radius: var(--input-border-radius);
}

.form-field .hc-multiselect-toggle:focus {
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
  border: var(--input-border-width) solid var(--input-border-color-focus);
  text-decoration: none;
}

.form-field textarea {
  vertical-align: middle;
}

.form-field input[type=checkbox] + label {
  margin: 0 0 0 var(--spacing-1-5);
}

.form-field .optional {
  color: #555;
  margin-left: var(--spacing-0-5);
}

.form-field p {
  color: #555;
  font-size: var(--font-size-sm);
  margin: var(--spacing-0-5) 0;
}

.form footer {
  margin-top: var(--spacing-3);
  padding-top: var(--spacing-4);
}

.form footer a {
  color: #555;
  cursor: pointer;
  margin-right: var(--spacing-2);
}

.form .suggestion-list {
  font-size: var(--font-size-base);
  margin-top: var(--spacing-4);
}
.form .suggestion-list label {
  border-bottom: 1px solid var(--color-border-default);
  display: block;
  padding-bottom: var(--spacing-0-5);
}
.form .suggestion-list li {
  padding: var(--spacing-1-5) 0;
}
.form .suggestion-list li a:visited {
  color: rgba(0, 0, 0, 1);
}

/***** Header *****/
.header {
  width: 100%;
  background-color: var(--color-bg-body);
  border-bottom: 1px solid var(--color-border-dark);
}

body:has(.hero) .header {
  background-color: var(--color-brand-tertiary);
}

.header-content {
  /* Uses container pattern: margin auto, responsive padding, max-width on desktop */
  margin: 0 auto;
  padding: 0 var(--spacing-3); /* 24px on mobile */
  position: relative;
  align-items: center;
  display: flex;
  height: 5rem; /* 80px */
  gap: var(--spacing-3);
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .header-content {
    max-width: var(--container-max-width); /* 1440px - total width including padding */
    padding: 0 var(--spacing-6); /* 48px on each side */
  }
}

.logo {
  flex-grow: 1;
  flex-shrink: 1;
  display: flex;
  align-items: center;
}

.logo img {
  max-width: 220px;
  min-width: 120px;
  width: 100%;
  vertical-align: sub;
}

.logo-svg {
  height: 28px;
  width: auto;
  max-width: 127px;
  color: rgba(34, 34, 34, 1);
  display: block;
}
@media (min-width: 768px) {
  .logo-svg {
    height: 32px;
  }
}

.logo span {
  margin: 0 10px;
  color: rgba(34, 34, 34, 1);
}

.logo a {
  display: flex;
  align-items: center;
}

.logo a:hover, .logo a:focus, .logo a:active {
  text-decoration: none;
}

.user-nav {
  text-align: right;
  /*   display: inline-block;
  /*   display: inline-block; position: absolute; white-space: nowrap; */
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .user-nav {
    position: relative;
  }
}
.user-nav[aria-expanded=true] {
  background-color: var(--color-white);
  box-shadow: var(--shadow-md);
  border: solid 1px var(--color-border-default);
  right: 0;
  left: 0;
  top: 4.4375rem;
  z-index: var(--z-index-sticky);
}
.user-nav[aria-expanded=true] > a {
  display: block;
  margin: var(--spacing-3);
}
.user-nav[aria-expanded=true] > .user-nav-list li {
  display: block;
}
.user-nav[aria-expanded=true] > .user-nav-list a {
  display: block;
  margin: var(--spacing-3);
}

.user-nav-list {
  display: block;
  list-style: none;
}
.user-nav-list > li {
  display: inline-block;
}

.nav-wrapper-desktop {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

@media (min-width: 1024px) { /* --breakpoint-md */
  .nav-wrapper-desktop {
    display: inline-block;
  }
}


/* Website link - simple text link with underline */
.website-link {
  background-color: transparent;
  border: 0;
  padding: 0;
  border-radius: 0;
  font-weight: normal;
  color: var(--color-gray-dark);
  text-decoration: underline;
  transition: color var(--transition-fast) var(--ease-out);
}

.website-link:hover,
.website-link:focus {
  background-color: transparent;
  color: var(--color-black);
  text-decoration: none;
}

.website-link:active {
  background-color: transparent;
  color: var(--color-gray-dark);
}

@media (min-width: 1024px) { /* --breakpoint-md */
  .nav-wrapper-mobile {
    display: none;
  }
}
.nav-wrapper-mobile .menu-button-mobile {
  background: none;
  border: 0;
  width: auto;
  min-width: 4.4375rem;
  cursor: pointer;
}
.nav-wrapper-mobile .menu-button-mobile .icon-menu {
  padding: 7px; /* Specific icon padding - keep as-is */
  vertical-align: middle;
  width: var(--spacing-4); /*32px*/
  height: var(--spacing-4); /*32px*/
  border-radius: var(--radius-full);
}
.nav-wrapper-mobile .menu-button-mobile[aria-expanded=true] .icon-menu {
  background: var(--color-gray-bg);
}
.nav-wrapper-mobile .menu-list-mobile {
  position: absolute;
  background-color: var(--color-white);
  box-shadow: var(--shadow-lg);
  border-top: solid 1px var(--color-border-default);
  border-bottom: solid 1px var(--color-border-default);
  right: 0;
  left: 0;
  top: 5rem; /*80px*/
  z-index: var(--z-index-fixed);
}
.nav-wrapper-mobile .menu-list-mobile[aria-expanded=false] {
  display: none;
}
.nav-wrapper-mobile .menu-list-mobile[aria-expanded=true] {
  display: block;
}
.nav-wrapper-mobile .menu-list-mobile-items .item {
  margin: var(--spacing-0-5) 0;
}
.nav-wrapper-mobile .menu-list-mobile-items li:empty:not(.nav-divider) {
  display: none;
}
.nav-wrapper-mobile .menu-list-mobile-items .nav-divider {
  border-bottom: 0.1px solid var(--color-border-default);
  padding: 0;
}
.nav-wrapper-mobile .menu-list-mobile-items .nav-divider:last-child {
  display: none;
}
.nav-wrapper-mobile .menu-list-mobile-items button {
  background: none;
  border: none;
  padding: var(--spacing-1) var(--spacing-3);
  width: 100%;
  height: 100%;
  color: rgba(34, 34, 34, 1);
  cursor: pointer;
  text-align: start;
}
.nav-wrapper-mobile .menu-list-mobile-items button:active, .nav-wrapper-mobile .menu-list-mobile-items button:focus, .nav-wrapper-mobile .menu-list-mobile-items button:hover {
  background-color: var(--color-gray-bg);
  text-decoration: underline;
}
.nav-wrapper-mobile .menu-list-mobile-items a {
  display: block;
  padding: var(--spacing-1) var(--spacing-3);
  width: 100%;
  height: 100%;
  color: rgba(34, 34, 34, 1);
}
.nav-wrapper-mobile .menu-list-mobile-items a:active, .nav-wrapper-mobile .menu-list-mobile-items a:focus, .nav-wrapper-mobile .menu-list-mobile-items a:hover {
  background-color: var(--color-gray-bg);
}
.nav-wrapper-mobile .menu-list-mobile-items .my-profile {
  display: flex;
  line-height: var(--line-height-normal);
}
.nav-wrapper-mobile .menu-list-mobile-items .my-profile .my-profile-tooltip {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}
.nav-wrapper-mobile .menu-list-mobile-items .menu-profile-avatar {
  height: 20px;
  width: 20px;
  border-radius: 50%;
  display: inline-block;
  margin-right: var(--spacing-1);
  margin-top: 1px;
}
[dir=rtl] .nav-wrapper-mobile .menu-list-mobile-items .menu-profile-avatar {
  margin-right: 0;
  margin-left: var(--spacing-1);
}

.skip-navigation {
  align-items: center;
  background-color: black;
  color: white;
  display: flex;
  font-size: var(--font-size-md);
  justify-content: center;
  left: -999px;
  margin: var(--spacing-3);
  padding: var(--spacing-3);
  overflow: hidden;
  position: absolute;
  top: auto;
  z-index: -999;
}
[dir=rtl] .skip-navigation {
  left: initial;
  right: -999px;
}
.skip-navigation:focus, .skip-navigation:active {
  left: auto;
  overflow: auto;
  text-align: center;
  text-decoration: none;
  top: auto;
  z-index: var(--z-index-modal-backdrop);
}
[dir=rtl] .skip-navigation:focus, [dir=rtl] .skip-navigation:active {
  left: initial;
  right: auto;
}

#zd-modal-container ~ .skip-navigation {
  display: none;
}

/***** User info in header *****/
.user-info {
  display: inline-block;
}
.user-info .dropdown-toggle::after {
  display: none;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .user-info .dropdown-toggle::after {
    display: inline-block;
  }
}
.user-info > button {
  border: 0;
  color: rgba(34, 34, 34, 1);
  min-width: 0;
  padding: 0;
  white-space: nowrap;
}
.user-info > button:hover, .user-info > button:focus {
  color: rgba(34, 34, 34, 1);
  background-color: transparent;
}
.user-info > button::after {
  color: rgba(34, 34, 34, 1);
  padding-right: var(--spacing-2);
}
[dir=rtl] .user-info > button::after {
  padding-left: var(--spacing-2);
  padding-right: 0;
}

#user #user-name {
  display: none;
  font-size: var(--font-size-md);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  #user #user-name {
    display: inline-block;
  }
}
#user #user-name:hover {
  text-decoration: underline;
}

/***** User avatar *****/
.user-avatar {
  height: var(--spacing-3); /*24px*/
  width: var(--spacing-3); /*24px*/
  border-radius: var(--radius-full);
  display: inline-block;
  vertical-align: middle;
}

.avatar {
  display: inline-block;
  position: relative;
}
.avatar img {
  height: 2.5rem; /*40px*/
  width: 2.5rem; /*40px*/
}
.avatar .icon-agent {
  color: rgba(34, 34, 34, 1);
  border: 2px solid var(--color-white);
  border-radius: var(--radius-full);
  bottom: -var(--spacing-0-5);
  background-color: rgba(255, 255, 255, 1);
  font-size: var(--font-size-lg);
  height: var(--spacing-3); /*24px*/
  line-height: var(--font-size-base); /*16px*/
  position: absolute;
  right: -var(--spacing-0-5);
  text-align: center;
  width: var(--spacing-3); /*24px*/
}

/***** Footer *****/
.footer {
  border-top: 1px solid var(--color-black);
  margin-top: var(--spacing-6);
  padding: var(--spacing-4) 0;
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .footer {
    margin-top: var(--spacing-7);
  }
}

.footer a {
}
.footer-inner {
  /* Uses container pattern: margin auto, responsive padding, max-width on desktop */
  margin: 0 auto;
  padding: 0 var(--spacing-3); /* 24px on mobile */
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  row-gap: var(--spacing-3);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .footer-inner {
    max-width: var(--container-max-width); /* 1440px - total width including padding */
    padding: 0 var(--spacing-6); /* 48px on each side */
  }
}

.footer-logo {
  display: flex;
  justify-content: flex-start;
  width: 100%;
  max-width: 1440px;
}

.footer-logo-svg {
  width: 100%;
  height: auto;
  max-width: 100%;
  color: var(--color-brand-tertiary);
  display: block;
  margin: 0;
  transform: none;
}

.footer-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
}

.footer-language-selector button {
  color: #555;
  display: inline-block;
}

.powered-by-zendesk a,
.powered-by-zendesk a:visited {
  color: #555;
}

/***** Breadcrumbs *****/
.breadcrumbs {
  margin: 0 0 0.9375rem 0;
  padding: 0;
  display: flex;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .breadcrumbs {
    margin: 0;
  }
}
.breadcrumbs li {
  color: rgba(34, 34, 34, 1);
  font-size: var(--font-size-base);
  max-width: 450px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.breadcrumbs li + li::before {
  content: ">";
  margin: 0 var(--spacing-0-5);
}
.breadcrumbs li a:visited {
  color: rgba(34, 34, 34, 1);
}

/***** Search Component *****/
/* Purpose: All search-related styles including input, submit button, results, and sidebar */
/* Usage: Used in header, hero section, and search results pages */

/* Search Container - Wrapper for search input and controls */
.search-container {
  position: relative;
}

.search {
  border-color: var(--color-border-default);
  border-radius: var(--radius-lg);
  border-style: solid;
  border-width: var(--input-border-width);
  display: flex;
  position: relative;
  transition: border var(--transition-base) var(--ease-out);
}

.search:hover {
  border-color: var(--color-black);
  border-width: var(--input-border-width);
  transition: border var(--transition-base) var(--ease-out);
}

.search:focus-within {
  border-color: rgba(34, 34, 34, 1);
}
.search input[type=search],
.search .clear-button {
  background-color: var(--color-white);
  /* Match the outer search container radius so the border isn't visually cropped */
  border-radius: var(--radius-lg);
  border: none;
}
.search-full input[type=search], .search-full .clear-button {
  border-color: var(--color-white);
}
.search input[type=search] {
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
  color: var(--color-black);
  flex: 1 1 auto;
  height: var(--spacing-3);
  width: 100%;
  line-height: var(--spacing-3); /* Match height for vertical centering */
  vertical-align: middle;
}
.search input[type=search]:focus {
  color: var(--color-gray-dark);
}

/* Replace default blue focus ring with solid primary border on search fields */
.sub-nav .search input[type=search]:focus {
  outline: none;
  box-shadow: none;
}

.sub-nav .search:focus-within {
  outline: var(--focus-ring-width) solid var(--color-border-primary);
  outline-offset: 0;
}
.search input[type=search]::-webkit-search-decoration, .search input[type=search]::-webkit-search-cancel-button, .search input[type=search]::-webkit-search-results-button, .search input[type=search]::-webkit-search-results-decoration {
  -webkit-appearance: none;
}
.search input[type=search]:-webkit-autofill, .search input[type=search]:-webkit-autofill:hover, .search input[type=search]:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px var(--color-white) inset;
}
.search .clear-button {
  align-items: center;
  box-sizing: border-box;
  color: var(--color-gray-dark);
  cursor: pointer;
  display: none;
  flex: none;
  justify-content: center;
  padding: 0;
  width: var(--spacing-3); /* 24px - matches height */
  height: var(--spacing-3); /* 24px - matches width for square button */
  min-width: var(--spacing-3);
  min-height: var(--spacing-3);
}

/* Align internal search clear button vertically with text */
.sub-nav .search .clear-button {
  height: var(--spacing-4); /* 32px */
  width: var(--spacing-4);
  min-height: var(--spacing-4);
  align-self: center; /* vertically center within 48px search field */
}

.search .clear-button svg {
  width: var(--icon-size-small); /* 24px */
  height: var(--icon-size-small); /* 24px */
}

.search .clear-button:hover {
  color: var(--color-black);
  background-color: var(--color-bg-dark);
  border-radius: var(--radius-full) !important; /* Override LTR/RTL border-radius resets */
  border-bottom-left-radius: var(--radius-full) !important;
  border-top-left-radius: var(--radius-full) !important;
  border-bottom-right-radius: var(--radius-full) !important;
  border-top-right-radius: var(--radius-full) !important;
  transition: color var(--transition-base) var(--ease-out), background-color var(--transition-base) var(--ease-out);
}
.search .clear-button:focus {
  outline: 0;
  box-shadow: none;
}
.search-has-value .clear-button {
  display: flex;
}

[dir=ltr] .search input[type=search] {
  padding-left: var(--spacing-3);
  padding-right: var(--spacing-3);
}
[dir=ltr] .search-has-value input[type=search] {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
  border-right-color: transparent;
  line-height: var(--spacing-3); /* Ensure consistent line-height when clear button is visible */
}
[dir=ltr] .search-has-value input[type=search]:focus {
  border-right-color: rgba(34, 34, 34, 1);
}
[dir=ltr] .search .clear-button {
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-left-color: transparent;
}
[dir=ltr] .search .clear-button:focus {
  border-left-color: transparent;
}

[dir=rtl] .search input[type=search] {
  padding-left: var(--spacing-3);
  padding-right: 2.5rem;
}
[dir=rtl] .search-has-value input[type=search] {
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-left-color: transparent;
  line-height: var(--spacing-3); /* Ensure consistent line-height when clear button is visible */
}
[dir=rtl] .search-has-value input[type=search]:focus {
  border-left-color: rgba(34, 34, 34, 1);
}
[dir=rtl] .search .clear-button {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
  border-right-color: transparent;
}
[dir=rtl] .search .clear-button:focus {
  border-right-color: transparent;
}

.search-icon {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  position: absolute;
  left: 1.125rem;
  z-index: var(--z-index-sticky);
  width: 1.125rem;
  height: 1.125rem;
  color: var(--color-text-light);
  pointer-events: none;
}
[dir=rtl] .search-icon {
  left: auto;
  right: 0.9375rem;
}

/***** Hero component *****/
.hero {
  margin-bottom: 0;        /* let curve sit flush under it */
  position: relative;
  overflow: visible;       /* nothing to clip now */
}

/* Content block with background + padding (blue or pink area) */
.hero-inner {
  display: flex;
  padding: var(--spacing-6) var(--spacing-3);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  background-color: var(--color-brand-tertiary); /* or your blue hero color */
  position: relative;
  z-index: var(--z-index-sticky);
}

.hero-inner h2 {
  font-family: "Wulkan", serif;
  margin: 0 0 var(--spacing-3) 0;
}

.hero-paragraphs {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
  margin: 0;
}

@media screen and (min-width: 768px) {
  .hero-paragraphs {
    gap: var(--spacing-1-5);
  }
}

.hero-inner p {
  font-size: var(--font-size-lg);
  margin: 0;
}

.hero-inner .button.button-primary {
  width: auto;
  min-width: 200px;
  margin-top: var(--spacing-4);
  --button-bg: var(--color-brand-primary);
  --button-border-color: var(--color-brand-primary);
  --button-bg-hover: var(--color-accent-red-hover);
  --button-border-color-hover: var(--color-accent-red-hover);
}

@media screen and (min-width: 768px) {
  .hero-inner .button.button-primary {
    margin-top: var(--spacing-5);
  }
}

.hero-inner p a {
  text-decoration: underline;
}

.hero-inner p a:hover {
  text-decoration: none;
}

/* Desktop height */
@media screen and (min-width: 768px) {
  .hero-inner {
    min-height: 421px;
  }
  
  .hero-inner p {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-null);
  }
}

/* Full-width curve with no padding */
.hero-bottom-curve {
  line-height: 0;
}

.hero-bottom-curve-svg {
  display: block;
  width: 100%;
  height: auto;
}




/* Hero search - consolidated styles (content--search is only used inside .hero) */
.hero .content--search {
  position: relative;
  z-index: var(--z-index-fixed);
  padding: 0;
  width: 100%;
  max-width: var(--search-max-width);
  background: transparent;
  box-shadow: none;
}

.hero .content--search .search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  background: var(--color-white);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-brand-secondary);
  padding: var(--spacing-1-5);
  padding-left: var(--spacing-4);
  gap: var(--spacing-1-5);
  box-shadow: var(--shadow-md);
  transform: scale(1);
  transform-origin: center;
  transition-property: transform, box-shadow;
  transition-duration: 300ms, 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1), ease;
  will-change: transform;
}

.hero .content--search .search-wrapper:hover,
.hero .content--search .search-wrapper:active {
  box-shadow: var(--shadow-lg);
  transform: scale(1.02);
}

@media (min-width: 768px) {
  .hero .content--search .search-wrapper {
    padding-left: var(--spacing-5);
  }
}

.hero .content--search .search-wrapper:focus-within {
  outline: var(--focus-ring-width) solid var(--color-brand-secondary);
  outline-offset: 0;
}






.hero .content--search .search {
  position: relative;
  width: 100%;
  flex: 1;
  margin: 0;
  border: none;
  background: transparent;
}

.hero .content--search .search-icon {
  position: absolute;
  left: var(--spacing-2);
  top: 50%;
  transform: translateY(-50%);
  width: var(--spacing-2);
  height: var(--spacing-2);
  color: var(--color-black);
  pointer-events: none;
  z-index: var(--z-index-sticky);
}

.hero .content--search .search input[type=search] {
  padding: 0;
  font-size: var(--font-size-lg);
  border: none;
  background: transparent;
  outline: none;
}

.hero .content--search .search input[type=search]:focus {
  outline: none;
  border: none;
}

.hero .content--search .search:focus-within {
  border-color: var(--color-brand-secondary);
}

/* Standalone search section (outside hero) */
.content--search {
  margin: var(--spacing-6) auto var(--spacing-3) auto;
  padding: 0 var(--spacing-3);
  width: 100%;
  max-width: var(--search-max-width);
  display: flex;
  justify-content: center;
}

@media (min-width: 768px) {
  .content--search {
    padding: 0 var(--spacing-6);
    margin: var(--spacing-6) auto;
  }
}

.content--search .search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  background: var(--color-white);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border-default);
  padding: var(--spacing-1-5);
  padding-left: var(--spacing-4);
  gap: var(--spacing-1-5);
  box-shadow: var(--shadow-md);
  transform: scale(1);
  transform-origin: center;
  transition-property: transform, box-shadow;
  transition-duration: 300ms, 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1), ease;
  will-change: transform;
}

.content--search .search-wrapper:hover,
.content--search .search-wrapper:active {
  box-shadow: var(--shadow-lg);
  transform: scale(1.02);
}

@media (min-width: 768px) {
  .content--search .search-wrapper {
    padding-left: var(--spacing-5);
  }
}

.content--search .search-wrapper:focus-within {
  outline: var(--focus-ring-width) solid var(--color-brand-secondary);
  outline-offset: 0;
}

.content--search .search {
  position: relative;
  width: 100%;
  flex: 1;
  margin: 0;
  border: none;
  background: transparent;
}

.content--search .search input[type=search] {
  padding: 0;
  font-size: var(--font-size-lg);
  border: none;
  background: transparent;
  outline: none;
}

.content--search .search input[type=search]:focus {
  outline: none;
  border: none;
}

.content--search .search:focus-within {
  border-color: var(--color-brand-secondary);
}

/* Search Submit Button - Icon-only button for submitting search */
.search-submit-button {
  position: relative;
  width: var(--icon-button-size);
  height: var(--icon-button-size);
  min-width: var(--icon-button-size);
  border-radius: var(--radius-full);
  background-color: var(--color-accent-red);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  padding: 0;
  transition: background-color var(--transition-base) var(--ease-out);
  flex-shrink: 0;
}

.search-submit-button:hover {
  background-color: var(--color-accent-red-hover);
}

.search-submit-button:focus {
  outline: var(--focus-ring-width) solid var(--focus-ring-color);
  outline-offset: var(--focus-ring-offset);
}

.search-submit-button svg {
  width: var(--icon-button-icon-size);
  height: var(--icon-button-icon-size);
  stroke: currentColor;
}

/* Mobile-first: Regular search autocomplete positioning */
.search-container zd-autocomplete,
.search ~ zd-autocomplete {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  right: 0 !important;
  margin-top: var(--spacing-0-5) !important;
  width: 100% !important;
  transform: none !important;
}

.page-header {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .page-header {
    align-items: baseline;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: var(--spacing-2);
  }
}
.page-header .section-subscribe {
  flex-shrink: 0;
  margin-bottom: var(--spacing-1-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .page-header .section-subscribe {
    margin-bottom: 0;
  }
}
.page-header h1 {
  flex-grow: 1;
  margin-top: var(--spacing-2);
  margin-bottom: var(--spacing-3);
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .page-header h1 {
    margin-top: 0;
  }
}
.page-header-description {
  font-style: italic;
  margin: 0 0 1.875rem 0;
  word-break: break-word;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .page-header-description {
    flex-basis: 100%;
  }
}
.page-header .icon-lock {
  height: 20px;
  width: 20px;
  position: relative;
  left: -var(--spacing-0-5);
  vertical-align: baseline;
}

.sub-nav {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 0.9375rem 30px;
  justify-content: space-between;
  margin-bottom: var(--spacing-3);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .sub-nav {
    flex-direction: row;
    align-items: center;
    margin-bottom: var(--spacing-6);
  }
}
.sub-nav .breadcrumbs {
  margin: 0;
}
.sub-nav .search-container {
  width: 100%;
  max-width: 100%; /* Mobile: full width */
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .sub-nav .search-container {
    flex: 0 1 300px;
    max-width: 300px; /* Desktop: fixed width */
  }
}
.sub-nav .search {
  width: 100%;
}
.sub-nav .search input[type=search] {
  height: var(--spacing-6); /* 48px */
  line-height: var(--spacing-6);
  padding-left: calc(var(--spacing-3) + var(--spacing-2)); /* extra space for icon */
}
.sub-nav input[type=search]::after {
  font-size: var(--font-size-md);
}

/***** Blocks *****/
/* Used in Homepage#categories and Community#topics */
.blocks-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  list-style: none;
  padding: 0;
  gap: var(--spacing-1-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .blocks-list {
    margin: 0;
    gap: var(--spacing-3);
  }
}
.blocks-item {
  display: flex;
  flex: 1 0 100%; /* Mobile: full width, single column */
  max-width: 100%;
  text-align: center;
  padding: var(--card-padding);
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  border: 1px solid var(--color-border-default);
  border-radius: var(--card-border-radius);
  background: var(--card-bg);
  box-sizing: border-box;
  transition: border 0.2s var(--ease);
}

@media (min-width: 768px) {
  .blocks-item {
    padding: var(--spacing-3);
    flex: 0 0 calc(50% - var(--spacing-3) * 0.5); /* 2 cards per row accounting for gaps */
    max-width: calc(50% - var(--spacing-3) * 0.5);
  }
}

@media (min-width: 1024px) {
  .blocks-item {
    flex: 0 0 calc(33.333% - var(--spacing-3) * 0.67); /* 3 cards per row accounting for gaps */
    max-width: calc(33.333% - var(--spacing-3) * 0.67);
  }
}

.blocks-item:hover {
  border: 1px solid rgba(34, 34, 34, 1);
}
.blocks-item:hover *, .blocks-item:focus *, .blocks-item:active * {
  text-decoration: none;
}
.blocks-item-internal {
  background-color: transparent;
  border: 1px solid var(--color-border-default);
}
.blocks-item-internal .icon-lock {
  height: 0.9375rem;
  width: 0.9375rem;
  bottom: var(--spacing-0-5);
  position: relative;
}
.blocks-item-internal a {
  color: rgba(34, 34, 34, 1);
}

.blocks-item-link {
  color: rgba(34, 34, 34, 1);
  display: flex;
  flex-direction: column;
  flex: 1;
  border-radius: inherit;
  align-items: flex-start;
  gap: var(--spacing-2);
}
@media (min-width: 768px) {
  .blocks-item-link {
    gap: var(--spacing-3);
  }
}

.blocks-item-link:visited, .blocks-item-link:hover, .blocks-item-link:active {
  color: inherit;
  text-decoration: none;
}

.blocks-item-title {
  font-size: var(--font-size-xl);
  font-weight: 600;
  letter-spacing: -0.24px;
  text-align: left;
}
@media (min-width: 768px) {
  .blocks-item-title {
    font-size: var(--font-size-2xl);
  }
}

.blocks-item-description:empty {
  /* display: none; */
}

.blocks-item-text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-0-5); /* 4px gap between title and description */
}

.blocks-item-description:not(:empty) {
  text-align: left;
  font-size: var(--font-size-base);
  color: var(--color-text-light);
}

.blocks-item-icon {
  align-items: center;
  line-height: 0;
}

/***** Homepage *****/

.section {
  margin-bottom: var(--spacing-6);
}

/* Knowledge base section - mobile max-width (mobile-first) */
.section.knowledge-base {
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
}

.home-section h3 {
  margin-bottom: var(--spacing-1-5);
  text-align: center;
}

/***** Promoted articles *****/
.promoted-articles {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .promoted-articles {
    flex-direction: row;
  }
}
.promoted-articles-item {
  flex: 1 0 auto;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .promoted-articles-item {
    align-self: flex-end;
    flex: 0 0 auto;
    padding-right: var(--spacing-4);
    width: 33%; /* Three columns on desktop */;
  }
  [dir=rtl] .promoted-articles-item {
    padding: 0 0 0 1.875rem;
  }
}
.promoted-articles-item:nth-child(3n) {
  padding-right: 0;
}
.promoted-articles-item a {
  display: block;
  border-bottom: 1px solid var(--color-border-default);
  padding: var(--spacing-2) 0;
}
.promoted-articles-item .icon-lock {
  vertical-align: baseline;
}
.promoted-articles-item:last-child a {
  border: 0;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .promoted-articles-item:last-child a {
    border-bottom: 1px solid var(--color-border-default);
  }
}

/***** Community section in homepage *****/
.community {
  text-align: center;
}
.community-image {
  min-height: 300px;
  margin-top: var(--spacing-4);
  background-image: url(/hc/theming_assets/01HZPPT7YZNNVMQJ6TX7B9E47D);
  background-position: center;
  background-repeat: no-repeat;
  max-width: 100%;
}
.community a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.community a:visited {
  color: rgba(0, 0, 0, 1);
}
.community a:hover, .community a:active, .community a:focus {
  color: rgba(0, 0, 0, 1);
}

.community,
.activity {
  border-top: 1px solid var(--color-border-default);
  padding: var(--spacing-3) 0;
}

/***** Recent activity *****/
.recent-activity-header {
  margin-bottom: var(--spacing-1-5);
  text-align: center;
}
.recent-activity-list {
  padding: 0;
}
.recent-activity-item {
  border-bottom: 1px solid var(--color-border-default);
  overflow: auto;
  padding: var(--spacing-3) 0;
}
.recent-activity-item h3 {
  margin: 0;
}
.recent-activity-item-parent {
  font-size: var(--font-size-base);
  font-weight: 600;
}
.recent-activity-item-parent, .recent-activity-item-link {
  margin: 6px 0;
  display: inline-block;
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .recent-activity-item-parent, .recent-activity-item-link {
    width: 70%;
    margin: 0;
  }
}
.recent-activity-item-link {
  font-size: var(--font-size-md);
  overflow: hidden;
  text-overflow: ellipsis;
}
.recent-activity-item-meta {
  color: rgba(34, 34, 34, 1);
  margin: 0.9375rem 0 0 0;
  float: none;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .recent-activity-item-meta {
    margin: 0;
    float: right;
  }
  [dir=rtl] .recent-activity-item-meta {
    float: left;
  }
}
.recent-activity-item-time, .recent-activity-item-comment {
  display: inline-block;
  font-size: var(--font-size-base);
}
.recent-activity-item-comment {
  padding-left: var(--spacing-0-5);
}
[dir=rtl] .recent-activity-item-comment {
  padding: 0 var(--spacing-0-5) 0 0;
}
.recent-activity-item-comment::before {
  display: inline-block;
}
.recent-activity-controls {
  padding-top: var(--spacing-2);
}
.recent-activity-controls a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.recent-activity-controls a:visited {
  color: rgba(0, 0, 0, 1);
}
.recent-activity-controls a:hover, .recent-activity-controls a:active, .recent-activity-controls a:focus {
  color: rgba(0, 0, 0, 1);
}
.recent-activity-comment-icon svg {
  vertical-align: middle;
  color: rgba(34, 34, 34, 1);
  width: var(--spacing-2);
  height: var(--spacing-2);
}
.recent-activity-comment-icon:after {
  content: attr(data-comment-count);
  margin-left: var(--spacing-0-5);
}
[dir=rtl] .recent-activity-comment-icon:after {
  margin-left: 0;
  margin-right: var(--spacing-0-5);
}

/***** Category pages *****/
.category-container {
  display: flex;
  justify-content: flex-end;
}
.category-content {
  flex: 1;
  max-width: 100%;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .category-content {
    flex: 0 0 80%;
  }
}

.section-tree {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .section-tree {
    flex-direction: row;
  }
}
.section-tree .section {
  flex: initial;
  max-width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .section-tree .section {
    flex: 0 0 45%; /* Two columns for tablet and desktop. Leaving 5% separation between columns */;
  }
}
.section-tree-title {
  margin-bottom: 0;
  font-size: var(--font-size-lg);
  font-weight: 600;
}
.section-tree-title a {
  color: rgba(34, 34, 34, 1);
}
.section-tree .see-all-articles {
  display: block;
  padding: var(--spacing-2) 0;
}

.article-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}

.article-list-item {
  margin: 0;
}

.article-list-item a:hover,
.article-list-item a:focus {
  text-decoration: none;
}

.article-list-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--card-padding);
  border: 1px solid var(--color-border-default);
  border-radius: var(--card-border-radius);
  background: var(--card-bg);
  box-sizing: border-box;
  width: 100%;
  transition: border 0.2s var(--ease);
}

.article-list-title {
  font-weight: 600;
  font-family: "Moderat", 'Helvetica Neue', Arial, Helvetica, sans-serif;
  font-size: var(--font-size-lg); /* 18px */
  margin: 0;
}

.article-list-text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1); /* 8px */
}

.article-list-excerpt {
  margin: 0;
}

.article-list-link:hover,
.article-list-link:focus {
  border: 1px solid rgba(34, 34, 34, 1);
  text-decoration: none;
}

.article-contact {
  text-align: center;
  margin: auto;
  max-width: 378px;
  padding: var(--spacing-3) 0 var(--spacing-6) 0;
}

.article-contact h3 {
  margin-bottom: 1.125rem;
}

.icon-star {
  color: rgba(34, 34, 34, 1);
  font-size: var(--font-size-lg);
}

/***** Section pages *****/
.section-container {
  display: flex;
  justify-content: center;
}
.section-content {
  flex: 1;
  max-width: 100%;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .section-content {
    flex: 0 0 80%;
    max-width: var(--search-max-width); /* 648px */
    margin: 0 auto;
  }
}
.section-list {
  margin: 2.5rem 0;
}

.section-list-item {
  border-bottom: 1px solid var(--color-border-default);
  font-size: var(--font-size-base);
  padding: var(--spacing-2) 0;
}
.section-list-item:first-child {
  border-top: 1px solid var(--color-border-default);
}
.section-list-item a {
  align-items: center;
  color: rgba(34, 34, 34, 1);
  display: flex;
  justify-content: space-between;
}

.see-all-sections-trigger {
  cursor: pointer;
  display: block;
  padding: var(--spacing-2);
  text-align: center;
}
.see-all-sections-trigger[aria-hidden=true] {
  display: none;
}

/***** Article Component *****/
/* Purpose: All article page styles including layout, header, content, sidebar, footer, and related content */
/* Usage: Applied to article pages with main content and sidebar navigation */

/* Article Container & Layout - Main wrapper for article page */
.article {
  flex: 1 0 auto;
  max-width: 100%;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .article {
    /* Constrain article to 648px but keep it left-aligned after the sidebar */
    flex: 0 1 var(--search-max-width);
    max-width: var(--search-max-width); /* 648px */
    margin: 0;
    padding: 0;
  }
}
.article-container {
  display: flex;
  flex-direction: column;
  /* Let sidebar and article use their intrinsic heights instead of stretching */
  align-items: flex-start;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .article-container {
    flex-direction: row;
    /* 48px gap between sidebar and main content */
    column-gap: var(--spacing-6); /* 3rem = 48px */
  }
}

/* Article Header - Title, author, metadata */
.article-header {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: var(--spacing-3);
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .article-header {
    flex-direction: row;
    margin-top: 0px;
  }
}

.article-header h1 {
  line-height: var(--line-height-tight);
  margin-bottom: var(--spacing-2);
}

.article-avatar {
  margin-right: var(--spacing-1-5);
}
.article-author {
  margin-bottom: var(--spacing-1-5);
}
.article-title {
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .article-title {
    flex-basis: 100%; /* Take entire row */;
  }
}
.article-title .icon-lock {
  position: relative;
  left: -var(--spacing-0-5);
  vertical-align: baseline;
}
.article [role=button] {
  flex-shrink: 0; /*Avoid collapsing elements in Safari (https://github.com/philipwalton/flexbugs#1-minimum-content-sizing-of-flex-items-not-honored)*/;
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .article [role=button] {
    width: auto;
  }
}
.article-info {
  max-width: 100%;
}
.article-meta {
  display: inline-block;
  vertical-align: middle;
}
.article-body {
  display: flow-root;
}
.article-body a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.article-body a:visited {
  color: rgba(0, 0, 0, 1);
}
.article-body a:hover, .article-body a:active, .article-body a:focus {
  color: rgba(0, 0, 0, 1);
}
.article-body img {
  height: auto;
  max-width: 100%;
  margin-top: var(--spacing-2);
  margin-bottom: var(--spacing-2);
}
.article-body p > img.image-style-align-left {
  float: left;
  margin: var(--spacing-1) 20px 6px 0;
}
.article-body p > img.image-style-align-right {
  float: right;
  margin: var(--spacing-1) 0px 6px 20px;
}
.article-body p > img.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.article-body p > img.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.article-body figure.image {
  display: table;
  margin: 0 auto;
}
.article-body figure.image > img {
  display: block;
  width: 100%;
}
.article-body figure.image.image-style-align-left {
  float: left;
  margin: var(--spacing-1) 20px 6px 0;
}
.article-body figure.image.image-style-align-right {
  float: right;
  margin: var(--spacing-1) 0px 6px 20px;
}
.article-body figure.image.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.article-body figure.image.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.article-body figcaption {
  padding: var(--spacing-1-5) 0;
  font-size: var(--font-size-sm);
  text-align: center;
  background-color: #fff3e1;
}
.article-body ul,
.article-body ol {
  list-style-position: outside;
  margin: var(--spacing-3) 0 var(--spacing-3) var(--spacing-3);
}
[dir=rtl] .article-body ul,
[dir=rtl] .article-body ol {
  padding-right: var(--spacing-3);
  padding-left: 0;
  margin-left: 0;
  margin-right: var(--spacing-3);
}
.article-body ul > ul,
.article-body ol > ol,
.article-body ol > ul,
.article-body ul > ol,
.article-body li > ul,
.article-body li > ol {
  margin: 0;
}
.article-body ul {
  list-style-type: disc;
}
.article-body :not(pre) > code {
  background: #fff7eb;
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-sm);
  padding: 0 var(--spacing-0-5);
  margin: 0 var(--spacing-0-5);
}
.article-body pre {
  background: #fff7eb;
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-sm);
  padding: var(--spacing-1) 0.9375rem;
  overflow: auto;
  white-space: pre;
}
.article-body blockquote {
  border-left: 1px solid var(--color-border-default);
  color: #555;
  font-style: italic;
  padding: 0 0.9375rem;
}
.article-body > p:last-child {
  margin-bottom: 0;
}

.article-body p strong {
  font-weight: 600;
}

.article-body h2 {
  padding-top: var(--spacing-3);
  padding-bottom: var(--spacing-1-5);
}

.article-body h3 {
  padding-top: var(--spacing-2);
}

.article-content {
  line-height: var(--line-height-relaxed);
  margin: 0 0 3rem;
  word-wrap: break-word;
}
.article-footer {
  align-items: center;
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
  flex-direction: column;
  border-top: 1px solid var(--color-border-default);
  /* Ensure footer text matches body size */
  font-size: var(--font-size-base);
}

.article-footer p,
.article-footer a {
  font-size: var(--font-size-base);
}
.article-comment-count {
  color: #555;
}
.article-comment-count:hover {
  text-decoration: none;
}
.article-comment-count-icon {
  vertical-align: middle;
  color: rgba(34, 34, 34, 1);
  width: 1.125rem;
  height: 1.125rem;
}
/* Article Sidebar - Navigation sidebar with section articles list */
.article-sidebar {
  /* Sidebar uses body default font size */
  font-size: var(--font-size-base);

  /* Mobile: hide sidebar entirely */
  display: none;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .article-sidebar {
    /* Fixed width sidebar on desktop */
    display: block;
    flex: 0 0 300px;
    height: auto;
    max-width: 300px;

    /* Desktop: remove mobile card treatment and align with article layout */
    background: none;
    border: 0;
    box-shadow: none;
    margin: 0;
    padding: 0 var(--card-padding) 0 0;
  }
}

/* Divider between each article title in the sidebar */
.article-sidebar .collapsible-sidebar-body ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.article-sidebar .collapsible-sidebar-body li + li {
  border-top: 1px solid var(--color-border-default);

}
/* Article Related/Recent - Related articles and recently viewed sections */
.article-relatives {
  border-top: 1px solid var(--color-border-default);
  display: flex;
  flex-direction: column;
  padding: var(--spacing-3) 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .article-relatives {
    flex-direction: row;
  }
}
.article-relatives > * {
  flex: 1 0 50%;
  min-width: 50%;
  overflow-wrap: break-word;
  margin-right: 0;
}
.article-relatives > *:last-child {
  padding: 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .article-relatives > * {
    padding-right: var(--spacing-3);
  }
}
/* Article Voting - Helpful/Not helpful voting section */
.article-votes {
  border-top: 1px solid var(--color-border-default);
  padding: var(--spacing-4) 0;
  text-align: center;
}
.article-votes-question {
  font-size: var(--font-size-base);
  font-weight: normal;
  margin-bottom: 0;
}
.article-vote {
  margin: var(--spacing-1) var(--spacing-0-5);
  min-width: 96px;
  width: auto;
}
.article-more-questions {
  margin: var(--spacing-1) 0 var(--spacing-3);
  text-align: center;
}
.article-more-questions a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.article-more-questions a:visited {
  color: rgba(0, 0, 0, 1);
}
.article-more-questions a:hover, .article-more-questions a:active, .article-more-questions a:focus {
  color: rgba(0, 0, 0, 1);
}
.article-return-to-top {
  border-top: 1px solid var(--color-border-default);
  width: 100%;
  margin: auto;
  text-align: center;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .article-return-to-top {
    display: none;
  }
}
.article-return-to-top a {
  color: rgba(34, 34, 34, 1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-1);
  padding: var(--spacing-3) 0;
}
.article-return-to-top a:hover, .article-return-to-top a:focus {
  text-decoration: none;
}
.article-return-to-top-icon {
  transform: rotate(0.5turn);
}
.article td > p:first-child,;
.article th > p:first-child {
  margin-top: 0;
}
.article td > p:last-child,;
.article th > p:last-child {
  margin-bottom: 0;
}

.sidenav-title {
  font-size: var(--font-size-md);
  position: relative;
  font-weight: 600;
}
.sidenav-item {
  display: block;
  margin-top: var(--spacing-2);
  margin-bottom: var(--spacing-2);
  overflow: hidden;
  text-overflow: ellipsis;
}
.current-article {
  font-weight: 600;
}

.recent-articles li,
.related-articles li {
  margin-bottom: var(--spacing-2);
}

/***** Attachments *****/
/* Styles attachments inside posts, articles and comments */
.attachments .attachment-item {
  padding-left: var(--spacing-3);
  position: relative;
  margin-bottom: var(--spacing-1-5);
}
.attachments .attachment-item:last-child {
  margin-bottom: 0;
}
.attachments .attachment-item .attachment-icon {
  color: rgba(34, 34, 34, 1);
  left: 0;
  position: absolute;
  top: var(--spacing-0-5);
}
[dir=rtl] .attachments .attachment-item {
  padding-left: 0;
  padding-right: var(--spacing-3);
}
[dir=rtl] .attachments .attachment-item .attachment-icon {
  left: auto;
  right: 0;
}

.upload-dropzone span {
  color: #555;
}

/***** Social share links *****/
.share {
  padding: 0;
  white-space: nowrap;
}

.share li, .share a {
  display: inline-block;
}

.share li {
  height: 1.5625rem;
  width: 1.5625rem;
}

.share a {
  color: #555;
}
.share a:hover {
  text-decoration: none;
  color: rgba(34, 34, 34, 1);
}
.share a svg {
  height: 1.125rem;
  width: 1.125rem;
  display: block;
}

/***** Comments *****/
/* Styles comments inside articles, posts and requests */
.comment {
  border-bottom: 1px solid var(--color-border-default);
  padding: var(--spacing-3) 0;
}
.comment-heading, .recent-articles-title,
.related-articles-title {
  margin-bottom: var(--spacing-0-5);
  margin-top: 0;
  font-size: var(--font-size-lg);
  font-weight: 600;
}
.comment-overview {
  border-bottom: 1px solid var(--color-border-default);
  border-top: 1px solid var(--color-border-default);
  padding: var(--spacing-3) 0;
}
.comment-overview p {
  margin-top: 0;
}
.comment-callout {
  color: #555;
  display: inline-block;
  font-size: var(--font-size-base);
  margin-bottom: 0;
}
.comment-callout a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.comment-callout a:visited {
  color: rgba(0, 0, 0, 1);
}
.comment-callout a:hover, .comment-callout a:active, .comment-callout a:focus {
  color: rgba(0, 0, 0, 1);
}
.comment-sorter {
  display: inline-block;
  float: right;
}
.comment-sorter .dropdown-toggle {
  color: #555;
  font-size: var(--font-size-base);
}
[dir=rtl] .comment-sorter {
  float: left;
}
.comment-wrapper {
  display: flex;
  position: relative;
}
.comment-wrapper.comment-official {
  border: 1px solid rgba(34, 34, 34, 1);
  padding: 2.5rem 20px 20px;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .comment-wrapper.comment-official {
    padding-top: var(--spacing-3);
  }
}
.comment-info {
  min-width: 0;
  padding-right: var(--spacing-3);
  width: 100%;
}
[dir=rtl] .comment-info {
  padding-right: 0;
  padding-left: var(--spacing-3);
}
.comment-author {
  align-items: flex-end;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: var(--spacing-3);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .comment-author {
    justify-content: space-between;
  }
}
.comment-avatar {
  margin-right: var(--spacing-1-5);
}
[dir=rtl] .comment-avatar {
  margin-left: var(--spacing-1-5);
  margin-right: 0;
}
.comment-meta {
  flex: 1 1 auto;
}
.comment-labels {
  flex-basis: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .comment-labels {
    flex-basis: auto;
  }
}
.comment .status-label:not(.status-label-official) {
  margin-top: var(--spacing-1-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .comment .status-label:not(.status-label-official) {
    margin-top: 0;
  }
}
.comment-form {
  display: flex;
  padding-top: var(--spacing-4);
  word-wrap: break-word;
}
.comment-container {
  width: 100%;
}
.comment-form-controls {
  display: none;
  margin-top: var(--spacing-1-5);
  text-align: left;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  [dir=ltr] .comment-form-controls {
    text-align: right;
  }
}
.comment-form-controls input[type=submit] {
  margin-top: var(--spacing-2);
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .comment-form-controls input[type=submit] {
    margin-left: var(--spacing-2);
  }
  [dir=rtl] .comment-form-controls input[type=submit] {
    margin-left: 0;
    margin-right: var(--spacing-2);
  }
}
.comment-form-controls input[type=checkbox] {
  margin-right: var(--spacing-0-5);
}
.comment-form-controls input[type=checkbox] [dir=rtl] {
  margin-left: var(--spacing-0-5);
}
.comment-ccs {
  display: none;
}
.comment-ccs + textarea {
  margin-top: var(--spacing-1-5);
}
.comment-attachments {
  margin-top: var(--spacing-1-5);
}
.comment-attachments a {
  color: rgba(34, 34, 34, 1);
}
.comment-body {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  display: flow-root;
  font-family: 'Helvetica Neue', Arial, Helvetica, sans-serif;
  line-height: var(--line-height-relaxed);
  overflow-x: auto;
}
.comment-body a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.comment-body a:visited {
  color: rgba(0, 0, 0, 1);
}
.comment-body a:hover, .comment-body a:active, .comment-body a:focus {
  color: rgba(0, 0, 0, 1);
}
.comment-body img {
  height: auto;
  max-width: 100%;
}
.comment-body p > img.image-style-align-left {
  float: left;
  margin: var(--spacing-1) 20px 6px 0;
}
.comment-body p > img.image-style-align-right {
  float: right;
  margin: var(--spacing-1) 0px 6px 20px;
}
.comment-body p > img.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.comment-body p > img.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.comment-body figure.image {
  display: table;
  margin: 0 auto;
}
.comment-body figure.image > img {
  display: block;
  width: 100%;
}
.comment-body figure.image.image-style-align-left {
  float: left;
  margin: var(--spacing-1) 20px 6px 0;
}
.comment-body figure.image.image-style-align-right {
  float: right;
  margin: var(--spacing-1) 0px 6px 20px;
}
.comment-body figure.image.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.comment-body figure.image.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.comment-body figcaption {
  padding: var(--spacing-1-5) 0;
  font-size: var(--font-size-sm);
  text-align: center;
  background-color: #fff3e1;
}
.comment-body ul,
.comment-body ol {
  padding-left: var(--spacing-3);
  list-style-position: outside;
  margin: var(--spacing-3) 0 var(--spacing-3) var(--spacing-3);
}
[dir=rtl] .comment-body ul,
[dir=rtl] .comment-body ol {
  padding-right: var(--spacing-3);
  padding-left: 0;
  margin-left: 0;
  margin-right: var(--spacing-3);
}
.comment-body ul > ul,
.comment-body ol > ol,
.comment-body ol > ul,
.comment-body ul > ol,
.comment-body li > ul,
.comment-body li > ol {
  margin: 0;
}
.comment-body ul {
  list-style-type: disc;
}
.comment-body :not(pre) > code {
  background: #fff7eb;
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-sm);
  padding: 0 var(--spacing-0-5);
  margin: 0 var(--spacing-0-5);
}
.comment-body pre {
  background: #fff7eb;
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-sm);
  padding: var(--spacing-1) 0.9375rem;
  overflow: auto;
  white-space: pre;
}
.comment-body blockquote {
  border-left: 1px solid var(--color-border-default);
  color: #555;
  font-style: italic;
  padding: 0 0.9375rem;
}
.comment-mark-as-solved {
  display: inline-block;
}

/***** Vote *****/
/* Used in article comments, post comments and post */
.vote {
  display: flex;
  flex-direction: column;
  text-align: center;
}
.vote a:active, .vote a:hover, .vote a:focus {
  text-decoration: none;
}

.vote-sum {
  color: #555;
  display: block;
  margin: var(--spacing-0-5) 0;
}
[dir=rtl] .vote-sum {
  direction: ltr;
  unicode-bidi: bidi-override;
}

.vote-up svg {
  transform: scale(1, -1);
}

.vote-up:hover,;
.vote-down:hover {
  color: rgba(34, 34, 34, 1);
}

.vote-up, .vote-down {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  color: #555;
  cursor: pointer;
  min-height: 35px;
  min-width: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vote-voted {
  color: rgba(34, 34, 34, 1);
}

.vote-voted:hover {
  color: #000;
}

/***** Actions *****/
/* Styles admin and en user actions(edit, delete, change status) in comments and posts */
.actions {
  text-align: center;
  flex-shrink: 0; /*Avoid collapsing elements in Safari*/;
}
.actions button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  cursor: pointer;
  min-height: 35px;
  min-width: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/***** Community *****/
.community-hero {
  background-image: url(/hc/theming_assets/01HZPPT6WGN5ZZDPDH3225VG2Y);
  margin-bottom: var(--spacing-1-5);
}
.community-footer {
  padding-top: var(--spacing-6);
  text-align: center;
}
.community-footer-title {
  font-size: var(--font-size-base);
  margin-bottom: var(--spacing-3);
}
.community-featured-posts .title {
  font-size: var(--font-size-lg);
  font-weight: 600;
}
.community-featured-posts, .community-activity {
  padding-top: 2.5rem;
  width: 100%;
}
.community-header {
  margin-bottom: var(--spacing-4);
}
.community-header .title {
  margin-bottom: 0;
  font-size: var(--font-size-base);
}

.post-to-community {
  margin-top: var(--spacing-1-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .post-to-community {
    margin: 0;
  }
}

/* Community topics grid */
.topics {
  max-width: none;
  width: 100%;
}
.topics-item .meta-group {
  justify-content: center;
  margin-top: 20px;
}

/* Community topic page */
.topic-header {
  border-bottom: 1px solid var(--color-border-default);
  font-size: var(--font-size-base);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .topic-header {
    padding-bottom: var(--spacing-1-5);
  }
}
.topic-header .dropdown {
  display: block;
  border-top: 1px solid var(--color-border-default);
  padding: var(--spacing-1-5) 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .topic-header .dropdown {
    border-top: 0;
    display: inline-block;
    margin-right: var(--spacing-3);
    padding: 0;
  }
}

.no-posts-with-filter {
  margin-top: 20px;
  margin-bottom: var(--spacing-3);
}

/* Topic, post and user follow button */
.community-follow {
  margin-bottom: var(--spacing-1-5);
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .community-follow {
    margin-bottom: 0;
    width: auto;
  }
}
.community-follow button {
  line-height: 1.875rem; /* 30px */
  padding: 0 var(--spacing-1) 0 0.9375rem;
  position: relative;
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .community-follow button {
    width: auto;
  }
}
.community-follow button:hover {
  background-color: rgba(34, 34, 34, 1);
}
.community-follow button:hover::after, .community-follow button:focus::after {
  border-color: rgba(255, 255, 255, 1);
  color: rgba(255, 255, 255, 1);
}
.community-follow button[data-selected=true] {
  background-color: rgba(34, 34, 34, 1);
  color: rgba(255, 255, 255, 1);
}
.community-follow button[data-selected=true]::after {
  border-left: 1px solid rgba(255, 255, 255, 1);
  color: rgba(255, 255, 255, 1);
}
.community-follow button[data-selected=true]:hover {
  background-color: #000;
  border-color: #000;
}
.community-follow button::after {
  border-left: 1px solid rgba(34, 34, 34, 1);
  content: attr(data-follower-count);
  color: rgba(34, 34, 34, 1);
  display: inline-block;
  font-family: 'Helvetica Neue', Arial, Helvetica, sans-serif;
  margin-left: var(--spacing-2);
  padding-left: var(--spacing-1-5);
  position: absolute;
  right: 10px;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .community-follow button::after {
    position: static;
  }
}
[dir=rtl] .community-follow button::after {
  border-left: 0;
  border-right: 1px solid rgba(34, 34, 34, 1);
  margin: 0 var(--spacing-1) 0 0;
  padding: 0 var(--spacing-1) 0 0;
}

/***** Striped list *****/
/* Used in community posts list and requests list */
.striped-list {
  padding: 0;
}
.striped-list-item {
  align-items: flex-start;
  border-bottom: 1px solid var(--color-border-default);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--spacing-3) 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .striped-list-item {
    align-items: center;
    flex-direction: row;
  }
}
.striped-list-info {
  flex: 2;
}
.striped-list-title {
  color: rgba(34, 34, 34, 1);
  margin-bottom: var(--spacing-1-5);
  margin-right: var(--spacing-0-5);
}
.striped-list-title:hover, .striped-list-title:focus, .striped-list-title:active {
  text-decoration: underline;
}
.striped-list-title:visited {
  color: rgba(0, 0, 0, 1);
}
.striped-list .meta-group {
  margin: var(--spacing-0-5) 0;
}
.striped-list-count {
  color: #555;
  font-size: var(--font-size-base);
  justify-content: flex-start;
  text-transform: capitalize;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .striped-list-count {
    display: flex;
    flex: 1;
    justify-content: space-around;
  }
}
.striped-list-count-item::after {
  content: "·";
  display: inline-block;
  padding: 0 var(--spacing-0-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .striped-list-count-item::after {
    display: none;
  }
}
.striped-list-count-item:last-child::after {
  display: none;
}
.striped-list-number {
  text-align: center;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .striped-list-number {
    color: rgba(34, 34, 34, 1);
    display: block;
  }
}

/***** Status labels *****/
/* Styles labels used in posts, articles and requests */
.status-label {
  background-color: var(--color-status-green);
  border-radius: var(--radius-md);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: 600;
  margin-right: var(--spacing-0-5);
  padding: var(--spacing-0-5) var(--spacing-1);
  vertical-align: middle;
  white-space: nowrap;
  display: inline-block;
}
.status-label:hover, .status-label:active, .status-label:focus {
  text-decoration: none;
}
.status-label-pinned, .status-label-featured, .status-label-official {
  background-color: rgba(34, 34, 34, 1);
}
.status-label-official {
  border-radius: 0;
  margin-right: 0;
  position: absolute;
  right: 0;
  text-align: center;
  top: 0;
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .status-label-official {
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    right: 1.875rem;
    width: auto;
  }
}
[dir=rtl] .status-label-official {
  left: 1.875rem;
  right: auto;
}
.status-label-not-planned, .status-label-closed {
  background-color: var(--color-border-default);
  color: #555;
}
.status-label-pending, .status-label-pending-moderation {
  background-color: var(--color-status-blue);
  text-align: center;
}
.status-label-open {
  background-color: var(--color-status-red);
}
.status-label-solved {
  background-color: var(--color-text-secondary);
}
.status-label-new {
  background-color: var(--color-status-yellow);
  color: var(--color-status-yellow-text);
}
.status-label-hold {
  background-color: var(--color-black);
}
.status-label-request {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 768px) {
  .status-label-request {
    max-width: 150px;
  }
}

/***** Post *****/
/*
/* * The post grid is defined this way: * Content | Sidebar * 70%     | 30% */
.post {
  flex: 1;
  margin-bottom: var(--spacing-1-5);
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .post {
    flex: 1 0 70%;
    max-width: 70%;
  }
}
.post-container {
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .post-container {
    flex-direction: row;
  }
}
.post-header {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-bottom: var(--spacing-1-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .post-header {
    align-items: baseline;
    flex-direction: row;
  }
}
.post-header .status-label {
  vertical-align: super;
}
.post-title {
  margin-bottom: var(--spacing-3);
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .post-title {
    margin-bottom: 0;
    padding-right: var(--spacing-1-5);
  }
}
.post-title h1 {
  display: inline;
  vertical-align: middle;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .post-title h1 {
    margin-right: var(--spacing-0-5);
  }
}
.post-author {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
}
.post-avatar {
  margin-bottom: var(--spacing-4);
}
.post-content {
  font-family: 'Helvetica Neue', Arial, Helvetica, sans-serif;
  line-height: var(--line-height-relaxed);
  word-break: break-word;
}
.post-info-container {
  display: flex;
  margin-bottom: 2.5rem;
}
.post-info {
  min-width: 0;
  padding-right: var(--spacing-3);
  width: 100%;
}
[dir=rtl] .post-info {
  padding-right: 0;
  padding-left: var(--spacing-3);
}
.post-meta {
  display: inline-block;
  flex: 1;
  margin-left: var(--spacing-1-5);
  vertical-align: middle;
}
[dir=rtl] .post-meta {
  margin-left: 0;
  margin-right: var(--spacing-1-5);
}
.post-body {
  display: flow-root;
}
.post-body a {
  color: rgba(34, 34, 34, 1);
  text-decoration: underline;
}
.post-body a:visited {
  color: rgba(0, 0, 0, 1);
}
.post-body a:hover, .post-body a:active, .post-body a:focus {
  color: rgba(0, 0, 0, 1);
}
.post-body img {
  height: auto;
  max-width: 100%;
}
.post-body p > img.image-style-align-left {
  float: left;
  margin: var(--spacing-1) 20px 6px 0;
}
.post-body p > img.image-style-align-right {
  float: right;
  margin: var(--spacing-1) 0px 6px 20px;
}
.post-body p > img.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.post-body p > img.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.post-body figure.image {
  display: table;
  margin: 0 auto;
}
.post-body figure.image > img {
  display: block;
  width: 100%;
}
.post-body figure.image.image-style-align-left {
  float: left;
  margin: var(--spacing-1) 20px 6px 0;
}
.post-body figure.image.image-style-align-right {
  float: right;
  margin: var(--spacing-1) 0px 6px 20px;
}
.post-body figure.image.image-style-block-align-right {
  margin-left: auto;
  margin-right: 0;
}
.post-body figure.image.image-style-block-align-left {
  margin-left: 0;
  margin-right: auto;
}
.post-body figcaption {
  padding: var(--spacing-1-5) 0;
  font-size: var(--font-size-sm);
  text-align: center;
  background-color: #fff3e1;
}
.post-body ul,
.post-body ol {
  padding-left: var(--spacing-3);
  list-style-position: outside;
  margin: var(--spacing-3) 0 var(--spacing-3) var(--spacing-3);
}
[dir=rtl] .post-body ul,
[dir=rtl] .post-body ol {
  padding-right: var(--spacing-3);
  padding-left: 0;
  margin-left: 0;
  margin-right: var(--spacing-3);
}
.post-body ul > ul,
.post-body ol > ol,
.post-body ol > ul,
.post-body ul > ol,
.post-body li > ul,
.post-body li > ol {
  margin: 0;
}
.post-body ul {
  list-style-type: disc;
}
.post-body :not(pre) > code {
  background: #fff7eb;
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-sm);
  padding: 0 var(--spacing-0-5);
  margin: 0 var(--spacing-0-5);
}
.post-body pre {
  background: #fff7eb;
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-sm);
  padding: var(--spacing-1) 0.9375rem;
  overflow: auto;
  white-space: pre;
}
.post-body blockquote {
  border-left: 1px solid var(--color-border-default);
  color: #555;
  font-style: italic;
  padding: 0 0.9375rem;
}
.post-footer {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding-bottom: 20px;
}
.post-comment-count {
  color: #555;
}
.post-comment-count:hover {
  text-decoration: none;
}
.post-comment-count .icon-comments {
  color: rgba(34, 34, 34, 1);
  display: inline-block;
  width: 1.125rem;
  height: 1.125rem;
  margin: var(--spacing-0-5); /* 4px - closest match to 5px */
  vertical-align: middle;
}
.post-sidebar {
  border-top: 1px solid var(--color-border-default);
  flex: 1;
  padding: var(--spacing-4) 0;
  text-align: center;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .post-sidebar {
    border: 0;
    flex: 1 0 30%;
    padding: 0 0 0 var(--spacing-6);
    text-align: initial;
  }
  [dir=rtl] .post-sidebar {
    padding: 0 var(--spacing-6) 0 0;
  }
}
.post-sidebar-title {
  font-size: var(--font-size-lg);
  font-weight: 600;
}
.post-comments {
  margin-bottom: var(--spacing-3);
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .post-comments {
    margin-bottom: 0;
  }
}

/***** Community Badges *****/
/* Styles labels used next to the authors of article comments, community posts, and community comments */
.community-badge-title {
  background-color: var(--color-status-teal);
  border-radius: var(--radius-md);
  color: var(--color-white);
  font-size: var(--font-size-sm);
  font-weight: 600;
  padding: 0px var(--spacing-1);
  vertical-align: top;
  white-space: nowrap;
  display: inline-block;
  line-height: 1.125rem; /* 18px */
  vertical-align: middle;
}

.community-badge-titles {
  display: inline;
}

.community-badge-achievement {
  display: block;
  height: var(--spacing-2);
  white-space: nowrap;
  width: var(--spacing-2);
}
.community-badge-achievement img {
  width: 100%;
  height: 100%;
}

.community-badge-achievements {
  display: flex;
}

.community-badge-achievements-rest {
  font-size: var(--font-size-sm);
  font-weight: 600;
  line-height: 1.25rem; /* 20px */
  text-align: center;
  vertical-align: top;
}

.community-badge {
  margin: var(--spacing-0-5); /* 4px - closest match to 2px */
}

.profile-info .community-badge-title {
  padding: var(--spacing-0-5) var(--spacing-1);
  line-height: 1.25rem; /* 20px */
}
.profile-info .community-badge-achievement {
  height: 2.5rem;
  width: 2.5rem;
}
.profile-info .community-badge-achievements-rest {
  line-height: 2.5rem; /* 40px */
  font-size: var(--font-size-xl);
}

/* Navigation element that collapses on mobile */
.collapsible-nav {
  flex-direction: column;
  font-size: var(--font-size-md);
  position: relative;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav {
    flex-direction: row;
  }
}

.collapsible-nav-border {
  border-bottom: 1px solid var(--color-border-default);
  border-top: 1px solid var(--color-border-default);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-border {
    border-top: 0;
  }
}

.collapsible-nav-toggle {
  top: var(--spacing-0-5);
  transform: translateY(-50%);
  position: absolute;
  right: 0;
  padding: 0;
  border: 0;
  background: none;
  width: 1.5625rem;
  height: 1.5625rem;
  border-radius: 50%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-toggle {
    display: none;
  }
}
[dir=rtl] .collapsible-nav-toggle {
  left: 0;
  right: auto;
}
.collapsible-nav-toggle-icon {
  display: none;
}
.collapsible-nav-toggle[aria-expanded=false] .chevron-icon {
  display: inline-block;
}
.collapsible-nav-toggle[aria-expanded=true] .x-icon {
  display: inline-block;
}
.collapsible-nav-toggle:focus {
  outline: none;
  border: 1px solid rgba(34, 34, 34, 1);
}

.collapsible-nav-list {
  display: flex;
  flex-direction: column;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-list {
    flex-direction: row;
  }
}
.collapsible-nav-list li {
  color: rgba(34, 34, 34, 1);
  line-height: 2.8125rem; /* 45px */
  order: 1;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-list li {
    line-height: normal;
    margin-right: var(--spacing-4);
  }
  [dir=rtl] .collapsible-nav-list li {
    margin-left: var(--spacing-4);
    margin-right: 0;
  }
  .collapsible-nav-list li a {
    text-decoration: none;
    padding: var(--spacing-2) 0;
  }
}
.collapsible-nav-list li a {
  color: rgba(34, 34, 34, 1);
  display: block;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-list li:hover {
    border-bottom: 4px solid var(--color-border-default);
  }
  .collapsible-nav-list li:hover a:not([aria-current=page]) {
    padding: 0.9375rem 0 11px 0;
    text-decoration: none;
  }
}
.collapsible-nav-list li:not([aria-selected=true]),;
.collapsible-nav-list li:not(.current) {
  display: none;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-list li:not([aria-selected=true]),;
  .collapsible-nav-list li:not(.current) {
    display: block;
  }
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-list li[aria-selected=true] {
    padding: 0.9375rem 0 11px 0;
  }
}
.collapsible-nav-list li[aria-selected=true],
.collapsible-nav-list li.current {
  order: 0;
  position: relative;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .collapsible-nav-list li[aria-selected=true],
  .collapsible-nav-list li.current {
    border-bottom: var(--spacing-0-5) solid rgba(34, 34, 34, 1);
    order: 1;
  }
}
.collapsible-nav-list li[aria-selected=true] a,
.collapsible-nav-list li.current a {
  color: rgba(34, 34, 34, 1);
}

.collapsible-nav[aria-expanded=true] li:not([aria-selected=true]),;
.collapsible-nav[aria-expanded=true] li:not(.current) {
  display: block;
}

/* Sidebar navigation that collapses on mobile */
.collapsible-sidebar {
  flex: 1;
  max-height: 48px;
  overflow: hidden;
  padding: var(--spacing-1-5) 0;
  position: relative;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .collapsible-sidebar {
    max-height: none;
    padding: 0;
  }
}
.collapsible-sidebar-title {
  margin-top: 0;
}
.collapsible-sidebar-toggle {
  position: absolute;
  /* Keep the icon aligned with the title text, even when the sidebar expands */
  top: var(--spacing-1-5); /* matches top padding of .collapsible-sidebar */
  transform: none;
  right: 0;
  padding: 0;
  border: 0;
  background: none;
  width: 1.5625rem;
  height: 1.5625rem;
  border-radius: 50%;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .collapsible-sidebar-toggle {
    display: none;
  }
}
[dir=rtl] .collapsible-sidebar-toggle {
  left: 0;
  right: auto;
}
.collapsible-sidebar-toggle-icon {
  display: none;
}
.collapsible-sidebar-toggle[aria-expanded=false] .chevron-icon {
  display: inline-block;
}
.collapsible-sidebar-toggle[aria-expanded=true] .x-icon {
  display: inline-block;
}
.collapsible-sidebar-toggle:focus {
  outline: none;
  border: 1px solid rgba(34, 34, 34, 1);
}
.collapsible-sidebar-body {
  display: none;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .collapsible-sidebar-body {
    display: block;
  }
}
.collapsible-sidebar[aria-expanded=true] {
  max-height: none;
}
.collapsible-sidebar[aria-expanded=true] .collapsible-sidebar-body {
  display: block;
}

/***** My activities *****/
.my-activities-nav {
  background-color: #fff3e1;
  margin-bottom: var(--spacing-3);
}
.my-activities-sub-nav {
  margin-bottom: var(--spacing-2);
}

.my-activities-table .striped-list-title {
  /* My activities tables */;
  display: block;
  margin-bottom: var(--spacing-1-5);
  max-width: 350px;
  white-space: normal;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .my-activities-table .striped-list-title {
    margin-bottom: 0;
    max-width: 500px;
    min-width: 350px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}
.my-activities-table thead {
  display: none;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .my-activities-table thead {
    display: table-header-group;
  }
}
.my-activities-table th:first-child,;
.my-activities-table td:first-child {
  padding-left: 0;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .my-activities-table th:first-child,;
  .my-activities-table td:first-child {
    width: 500px;
  }
}
.my-activities-table th:last-child,;
.my-activities-table td:last-child {
  padding-right: 0;
}
.my-activities-table td:not(:first-child) {
  display: none;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .my-activities-table td:not(:first-child) {
    display: table-cell;
  }
}

/* Requests table */
.requests-search {
  width: 100%;
}
.requests-table-toolbar {
  align-items: flex-end;
  display: flex;
  flex-direction: column;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests-table-toolbar {
    flex-direction: row;
  }
}
.requests-table-toolbar .search {
  flex: 1;
  width: 100%;
}
.requests-table-toolbar .request-table-filter {
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests-table-toolbar .request-table-filter {
    width: auto;
  }
}
.requests-table-toolbar .request-filter {
  display: block;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests-table-toolbar .request-filter {
    margin: 0 0 0 1.875rem;
  }
  [dir=rtl] .requests-table-toolbar .request-filter {
    margin: 0 1.875rem 0 0;
  }
}
.requests-table-toolbar .request-filter-label {
  font-size: var(--font-size-base);
  margin-top: var(--spacing-4);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests-table-toolbar .request-filter-label {
    margin-top: 0;
  }
}
.requests-table-toolbar select {
  max-height: 2.5rem;
  margin-bottom: var(--spacing-4);
  width: 100%;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests-table-toolbar select {
    margin-bottom: 0;
    max-width: 300px;
    width: auto;
  }
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests-table-toolbar .organization-subscribe {
    margin-left: var(--spacing-1-5);
  }
  [dir=rtl] .requests-table-toolbar .organization-subscribe {
    margin: 0 10px 0 0;
  }
}
.requests-table-toolbar .organization-subscribe button {
  line-height: 2.5rem; /* 40px */
  max-height: 2.5rem;
  padding: 0 var(--button-padding-x);
}
.requests-table-toolbar + .requests-search-info {
  margin-top: var(--spacing-2);
}
.requests-table-toolbar + .requests-search-info.meta-data::after {
  content: "";
  margin: 0;
}
.requests-table-toolbar + .requests-search-info + .requests {
  margin-top: 20px;
}
.requests-table-toolbar + .requests {
  margin-top: 2.5rem;
}
.requests .requests-table-meta {
  display: block;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests .requests-table-meta {
    display: none;
  }
}
.requests .requests-table thead {
  display: none;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests .requests-table thead {
    display: table-header-group;
  }
}
.requests .requests-table-info {
  display: block;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .requests .requests-table-info {
    display: table-cell;
    vertical-align: middle;
    width: auto;
  }
}
.requests .requests-table .requests-link {
  position: relative;
}
.requests .requests-table .requests-sort-symbol {
  position: absolute;
  left: calc(100% + var(--spacing-0-5));
  bottom: 0;
  font-size: var(--font-size-sm);
}

/* Following table */
@media (min-width: 768px) { /* --breakpoint-sm */
  .subscriptions-subscribe button {
    width: auto;
  }
}
.subscriptions-table td:last-child {
  display: block;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .subscriptions-table td:last-child {
    display: table-cell;
  }
}
.subscriptions-table td:first-child {
  display: flex;
  align-items: center;
}
.subscriptions-table .user-avatar {
  margin-right: var(--spacing-1-5);
}
.subscriptions .striped-list-title {
  display: inline-block;
  vertical-align: middle;
}

/* Contributions table */
.contributions-table td:last-child {
  color: #555;
  font-size: var(--font-size-base);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .contributions-table td:last-child {
    color: inherit;
    font-size: inherit;
    font-weight: inherit;
  }
}

.no-activities {
  color: #555;
}

/***** Request *****/
.request-container {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .request-container {
    align-items: flex-start;
    flex-direction: row;
  }
}
.request-container .comment-container {
  min-width: 0;
}
.request-breadcrumbs {
  margin-bottom: 2.5rem;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .request-breadcrumbs {
    margin-bottom: 3.75rem;
  }
}
.request-main {
  flex: 1 0 auto;
  order: 1;
}
.request-main .comment-fields, .request-main .request-submit-comment {
  display: none;
}
.request-main .comment-fields.shown {
  display: block;
}
.request-main .request-submit-comment.shown {
  display: inline;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .request-main {
    flex: 0 0 66%;
    order: 0;
    min-width: 0;
  }
}
.request-main .comment-form-controls {
  display: block;
}
.request-main .comment-ccs {
  display: block;
}
.request-main .comment-show-container {
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-default);
  color: #555;
  text-align: inherit;
  padding: var(--spacing-1) 1.5625rem; /* 25px */
  width: 100%;
}
.request-main .comment-show-container.hidden {
  display: none;
}
.request-main .form-field.comment-ccs > ul {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: 0;
}
.request-main .form-field.comment-ccs > ul[data-hc-focus=true] {
  border: 1px solid rgba(34, 34, 34, 1);
}
.request-main .form-field.comment-ccs > input[type=text] {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: 0;
}
.request-main .comment-ccs + textarea {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  margin-top: 0;
}
.request-main .comment-ccs + textarea:focus {
  border-top: 1px solid rgba(34, 34, 34, 1);
}
.request-main input#mark_as_solved {
  display: none;
}
.request-title {
  width: 100%;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .request-title {
    border-bottom: 1px solid var(--color-border-default);
    margin-bottom: 0;
    max-width: 66%;
    padding-bottom: 20px;
  }
}
.request-sidebar {
  border-bottom: 1px solid var(--color-border-default);
  border-top: 1px solid var(--color-border-default);
  flex: 1 0 auto;
  order: 0;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .request-sidebar {
    background-color: #fff7eb;
    border: 0;
    font-size: var(--font-size-base);
    flex: 0 0 auto;
    padding: 0 var(--button-padding-x);
    width: 30%;
  }
}
.request-sidebar h2 {
  font-size: var(--font-size-md);
  font-weight: 600;
  position: relative;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .request-sidebar h2 {
    display: none;
  }
}
.request-details {
  border-bottom: 1px solid var(--color-border-default);
  font-size: 0;
  margin: 0;
  padding-bottom: 20px;
}
.request-details:last-child {
  border: 0;
}
.request-details dt, .request-details dd {
  display: inline-block;
  vertical-align: top;
  font-size: var(--font-size-base);
  margin: var(--spacing-3) 0 0 0;
}
.request-details dd {
  padding: 0 var(--spacing-1);
  width: 60%;
}
.request-details dd::after {
  content: "\a";
  white-space: pre;
}
.request-details dt {
  color: #555;
  width: 40%;
}
.request-details .request-collaborators {
  display: inline-block;
}
.request-attachments dt, .request-attachments dd {
  width: 100%;
}
.request-attachments dd {
  margin: var(--spacing-1) 0 0 0;
}
.request-form textarea {
  min-height: 120px;
}
.request-follow-up {
  padding-top: var(--spacing-3);
}

/***** Pagination *****/
.pagination {
  margin: var(--spacing-3) 0;
  text-align: center; /* mobile-first: inline row of buttons */
}
.pagination-next, .pagination-prev, .pagination-first, .pagination-last {
  display: inline-block;
  margin: 0 var(--spacing-0-5);
}
.pagination-first-link, .pagination-last-link {
  /* Match vertical padding of other buttons, only tweak horizontal */
  padding: var(--button-padding-y) var(--spacing-1-5);
}
.pagination-next-link {
  padding-right: var(--spacing-1-5);
}
.pagination-next-text {
  margin-right: var(--spacing-1-5);
}
[dir=rtl] .pagination-next-link {
  padding-left: var(--spacing-1-5);
}
[dir=rtl] .pagination-next-text {
  margin-left: var(--spacing-1-5);
}
.pagination-prev-link {
  padding-left: var(--spacing-1-5);
}
.pagination-prev-text {
  margin-left: var(--spacing-1-5);
}
[dir=rtl] .pagination-prev-link {
  padding-right: var(--spacing-1-5);
}
[dir=rtl] .pagination-prev-text {
  margin-right: var(--spacing-1-5);
}

/* Ensure all pagination controls share the same visual height */
.pagination-next-link,
.pagination-prev-link,
.pagination-first-link,
.pagination-last-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 48px;
}


/***** Metadata *****/
.meta-group {
  display: block;
}

.meta-group-opposite {
  float: right;
}

[dir=rtl] .meta-group-opposite {
  float: left;
}

.meta-group * {
  display: inline;
}

.meta-data {
  color: #555;
  font-size: var(--font-size-base);
}
.meta-data:not(:last-child)::after {
  content: "·";
  margin: 0 var(--spacing-0-5);
}

/* User Profiles */
.profile-header {
  padding: var(--spacing-4) 0;
  background-color: #fff7eb;
}

.profile-header .container {
  display: flex;
  flex-wrap: wrap;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-header .container {
    flex-wrap: nowrap;
  }
}

.profile-header .profile-info {
  flex-basis: 100%;
  display: flex;
  flex-wrap: wrap;
  min-width: 0;
}

.profile-avatar {
  position: relative;
  line-height: 0;
  align-self: center;
  margin-right: var(--spacing-1-5);
}
[dir=rtl] .profile-avatar {
  margin-left: var(--spacing-1-5);
  margin-right: 0;
}

.profile-avatar .user-avatar {
  width: 80px;
  height: 80px;
}

.profile-avatar .icon-agent {
  bottom: 0;
  right: 0;
}

.profile-header .basic-info {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex-grow: 1;
  flex-basis: 0;
  min-width: 0;
}
.profile-header .basic-info .name {
  margin: 0;
  line-height: 1.5625rem; /* 25px */
  vertical-align: middle;
  display: inline;
}

.profile-header .options {
  display: flex;
  flex-basis: 100%;
  margin-top: var(--spacing-1-5);
  align-items: flex-start;
  flex-wrap: wrap;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-header .options {
    flex-wrap: nowrap;
    flex-basis: auto;
    margin-top: 0;
    margin-left: var(--spacing-1-5);
  }
  [dir=rtl] .profile-header .options {
    margin-left: 0;
    margin-right: var(--spacing-1-5);
  }
  .profile-header .options > :not(:last-child) {
    margin-bottom: 0;
    margin-right: var(--spacing-1-5);
  }
  [dir=rtl] .profile-header .options > :not(:last-child) {
    margin-left: var(--spacing-1-5);
    margin-right: 0;
  }
}

.user-profile-actions {
  width: 100%;
  margin-bottom: var(--spacing-2);
}

.profile-header .description {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  margin: 0.9375rem 0;
  flex-basis: 100%;
}

.profile-stats {
  font-size: var(--font-size-base);
  display: flex;
  flex-direction: column;
  flex-basis: 100%;
}

.profile-stats .stat {
  display: flex;
  margin-bottom: var(--spacing-1-5);
}

.profile-stats .stat-label {
  color: #555;
  flex: 0 0 6.25rem;
  margin-right: var(--spacing-1-5);
}
[dir=rtl] .profile-stats .stat-label {
  margin-left: var(--spacing-1-5);
  margin-right: 0;
}

.profile-stats-activity {
  border-top: solid 1px var(--color-border-default);
  margin-top: var(--spacing-2);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-activity {
    border-top: 0;
    flex-direction: row;
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-activity .stat {
    flex-direction: column;
  }
}

.profile-stats-activity .stat:first-child {
  margin-top: var(--spacing-1-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-activity .stat:first-child {
    margin-top: 0;
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-activity .stat:not(:last-child) {
    margin-right: 2.5rem;
  }
  [dir=rtl] .profile-stats-activity .stat:not(:last-child) {
    margin-left: 2.5rem;
    margin-right: 0;
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-activity .stat-label {
    flex: 0 1 auto;
  }
}

.profile-stats-counters {
  border-bottom: solid 1px var(--color-border-default);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-counters {
    flex: 0 0 200px;
    border-bottom: 0;
    margin-left: 2.5rem;
  }
  [dir=rtl] .profile-stats-counters {
    margin-left: 0;
    margin-right: 2.5rem;
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .profile-stats-counters {
    flex: 0 0 270px;
    margin-left: 3.75rem;
  }
  [dir=rtl] .profile-stats-counters {
    margin-right: 3.75rem;
    margin-left: 0;
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-counters .stat {
    flex-direction: column;
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .profile-stats-counters .stat {
    flex-direction: row;
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-counters .stat:not(:last-child) {
    margin-bottom: var(--spacing-2);
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-stats-counters .stat-label {
    flex: 0 1 auto;
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .profile-stats-counters .stat-label {
    flex: 0 0 6.25rem;
  }
}

.profile-private-badge {
  flex-basis: 100%;
  border: solid 1px rgba(34, 34, 34, 1);
  border-radius: var(--radius-md);
  color: rgba(34, 34, 34, 1);
  padding: var(--spacing-0-5) 20px;
  font-size: var(--font-size-sm);
  text-align: center;
}
.profile-private-badge .profile-private-icon {
  margin-left: var(--spacing-0-5);
  line-height: 0.9375rem; /* 15px */
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-private-badge {
    flex-basis: auto;
  }
}

.profile-nav {
  background-color: #fff3e1;
  margin-bottom: 37px;
}

.profile-section {
  width: 100%;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .profile-section {
    width: calc(100% - 330px);
  }
}

.profile-section-header {
  display: flex;
  flex-wrap: wrap;
}

.profile-section-title {
  flex-basis: 100%;
  margin-bottom: 0;
}

.profile-section-description {
  flex-basis: 100%;
  padding: var(--spacing-1-5) 0;
  color: #555;
  font-size: var(--font-size-base);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-section-description {
    flex: 1 0 50%;
    padding-bottom: 0;
  }
}

.profile-section-sorter {
  flex-basis: 100%;
  border-top: solid 1px var(--color-border-default);
  font-size: var(--font-size-base);
}
.profile-section-sorter .dropdown-toggle {
  padding: var(--spacing-1-5) 0;
  width: 100%;
}
.profile-section-sorter .dropdown-toggle::after {
  position: absolute;
  right: 0;
}
[dir=rtl] .profile-section-sorter .dropdown-toggle::after {
  left: 0;
  right: initial;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-section-sorter .dropdown-toggle::after {
    position: relative;
  }
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-section-sorter {
    flex: 0 1 auto;
    padding-top: 0;
    border-top: 0;
    margin-left: var(--spacing-3);
  }
  [dir=rtl] .profile-section-sorter {
    margin-left: 0;
    margin-right: var(--spacing-3);
  }
}

.profile-badges-items {
  margin-top: 1.5625rem;
}
.profile-badges-item {
  border-top: 1px solid var(--color-border-default);
  display: flex;
  flex: 1;
  flex-direction: row;
  justify-content: flex-start;
  padding: 1.6875rem var(--spacing-1-5); /* 27px 12px */
}
.profile-badges-item > div {
  padding-right: var(--spacing-1-5);
  padding-left: var(--spacing-1-5);
}
.profile-badges-item-image {
  height: 2.5rem;
  width: 2.5rem;
  margin-right: var(--spacing-1-5);
}
.profile-badges-item-image img {
  max-height: 2.5rem;
}
[dir=rtl] .profile-badges-item-image {
  margin-left: var(--spacing-1-5);
  margin-right: 0;
}
.profile-badges-item-title, .profile-badges-item-metadata-title {
  font-size: var(--font-size-md);
  margin-bottom: var(--spacing-1-5);
}
.profile-badges-item-title {
  font-weight: 600;
}
.profile-badges-item-description, .profile-badges-item-metadata-description {
  color: #555;
  font-size: var(--font-size-base);
  margin: 0;
}
.profile-badges-item-metadata {
  margin-left: auto;
  text-align: right;
}
[dir=rtl] .profile-badges-item-metadata {
  margin-left: 0;
  margin-right: auto;
  text-align: left;
}

.profile-contribution {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  padding: var(--spacing-3) 0;
  position: relative;
}

.profile-contribution-header {
  margin-bottom: var(--spacing-0-5);
}

.profile-contribution-title {
  margin: 0 0 var(--spacing-0-5) 0;
  display: inline;
  line-height: 1.3125rem; /* 21px */
  font-size: var(--font-size-md);
  vertical-align: middle;
}

.profile-contribution-body {
  margin: var(--spacing-1) 0;
}

.profile-contribution-list > .profile-contribution {
  border-top: 1px solid var(--color-border-default);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-contribution-list > .profile-contribution {
    padding-left: var(--spacing-4);
  }
  [dir=rtl] .profile-contribution-list > .profile-contribution {
    padding-right: var(--spacing-4);
    padding-left: 0;
  }
}

.profile-contribution-list > .profile-contribution:last-child {
  border-bottom: 1px solid var(--color-border-default);
}

.profile-contribution-icon {
  left: 0;
  position: absolute;
  color: var(--color-border-default);
  line-height: 1.5625rem; /* 25px */
}
[dir=rtl] .profile-contribution-icon {
  right: 0;
}
.profile-contribution-icon svg {
  vertical-align: middle;
}

.profile-contribution-list .profile-contribution-header {
  margin-left: var(--spacing-4);
}
[dir=rtl] .profile-contribution-list .profile-contribution-header {
  padding-right: var(--spacing-4);
  padding-left: 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-contribution-list .profile-contribution-header {
    margin-left: 0;
  }
  [dir=rtl] .profile-contribution-list .profile-contribution-header {
    padding-right: 0;
  }
}

.profile-comments .profile-contribution-breadcrumbs {
  margin-left: var(--spacing-4);
}
[dir=rtl] .profile-comments .profile-contribution-breadcrumbs {
  padding-right: var(--spacing-4);
  padding-left: 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-comments .profile-contribution-breadcrumbs {
    margin-left: 0;
  }
  [dir=rtl] .profile-comments .profile-contribution-breadcrumbs {
    padding-right: 0;
  }
}

.profile-section .no-activity,
.profile-section .private-activity {
  display: block;
  margin-top: 2.5rem;
  color: var(--color-gray-medium);
}

.private-activity-icon {
  margin-right: var(--spacing-1-5);
}
[dir=rtl] .private-activity-icon {
  margin-right: 0;
  margin-left: var(--spacing-1-5);
}

.profile-activity-list {
  margin-top: 1.5625rem;
}

.profile-activity {
  position: relative;
  padding-bottom: var(--spacing-4);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-activity {
    padding-left: var(--spacing-3);
  }
  [dir=rtl] .profile-activity {
    padding-right: var(--spacing-3);
    padding-left: 0;
  }
}

@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-activity:not(:last-child) {
    border-left: 1px solid var(--color-border-default);
  }
  [dir=rtl] .profile-activity:not(:last-child) {
    border-left: 0;
    border-right: 1px solid var(--color-border-default);
  }
}

.profile-activity-header {
  display: flex;
  align-items: center;
  margin-left: 35px;
}
[dir=rtl] .profile-activity-header {
  margin-left: 0;
  margin-right: 35px;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-activity-header {
    margin-left: 0;
  }
  [dir=rtl] .profile-activity-header {
    margin-right: 0;
  }
}

.profile-activity-header .user-avatar {
  width: 2.5rem;
  height: 2.5rem;
  margin-right: var(--spacing-1-5);
  min-width: 2.5rem;
  align-self: flex-start;
}
[dir=rtl] .profile-activity-header .user-avatar {
  margin-left: var(--spacing-1-5);
  margin-right: 0;
}

.profile-activity-description {
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  -webkit-hyphens: auto;
  word-break: break-word;
  word-wrap: break-word;
  margin: 0;
  min-width: 0;
  width: 100%;
}

.profile-activity-description span:first-child {
  font-weight: 600;
  display: inline;
}

.profile-activity-contribution {
  padding: var(--spacing-3);
  margin-top: var(--spacing-1-5);
  border-radius: var(--radius-lg);
  background-color: #fff7eb;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-activity-contribution {
    margin-top: 0;
    margin-left: 50px;
  }
  [dir=rtl] .profile-activity-contribution {
    margin-left: 0;
    margin-right: 50px;
  }
}

.profile-activity-icon {
  position: absolute;
  left: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-size: 14px 14px;
  background-repeat: no-repeat;
  background-color: rgba(255, 253, 250, 1);
  background-position: 50% 50%;
  text-align: center;
  color: var(--color-border-default);
}
[dir=rtl] .profile-activity-icon {
  right: 0;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .profile-activity-icon {
    left: -14px;
  }
  [dir=rtl] .profile-activity-icon {
    right: -14px;
  }
}

.profile-activity-icon svg {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  width: 1em;
  height: 1em;
  margin: auto;
}

/***** Search results *****/
.search-results {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .search-results {
    flex-direction: row;
  }
}
.search-results-column {
  flex: 1;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .search-results-column {
    flex: 0 0 75%;
  }
}
.search-results-sidebar {
  border-top: 1px solid var(--color-border-default);
  flex: 1 0 auto;
  margin-bottom: var(--spacing-3);
  padding: 0;
  display: none;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .search-results-sidebar {
    border: 0;
    flex: 0 0 20%;
    height: auto;
  }
}
.search-results-sidebar .sidenav-item {
  border-radius: var(--radius-md);
  padding: var(--spacing-1) var(--spacing-5);
  margin-bottom: var(--spacing-0-5);
  color: rgba(34, 34, 34, 1);
}

/* Desktop: center search results content with a max width */
@media (min-width: 1024px) {
  .search-results-column {
    flex: 0 1 auto;
    max-width: 40rem; /* 640px */
    margin-left: auto;
    margin-right: auto;
  }
}
.search-results-sidebar .sidenav-item:hover, .search-results-sidebar .sidenav-item.current {
  background-color: var(--color-border-default);
  text-decoration: none;
}
.search-results-sidebar .sidenav-subitem {
  unicode-bidi: embed;
}
.search-results-sidebar .sidenav-tag {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex-grow: 0;
}
.search-results-sidebar .sidenav-tag .content-tag {
  background: var(--color-border-default);
  border-radius: var(--radius-md);
  padding: var(--spacing-0-5) var(--spacing-1-5);
  text-decoration: none;
}
.search-results-sidebar .sidenav-tag .content-tag .label {
  font-style: normal;
  font-weight: 600;
  font-size: var(--font-size-sm);
  line-height: 1.5rem; /* 24px */
  text-align: center;
  letter-spacing: -0.0000267285rem; /* -0.000427656px */
  color: var(--color-text-medium);
  flex-grow: 0;
  vertical-align: middle;
  display: inline-block;
}
.search-results-sidebar .sidenav-tag .content-tag .close-icon {
  color: var(--color-gray-dark);
  vertical-align: middle;
  display: inline-block;
}
.search-results-sidebar .collapsible-sidebar {
  margin-bottom: var(--spacing-4);
}
.search-results-sidebar .collapsible-sidebar[aria-expanded=false] .multibrand-filter-list {
  display: none;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .search-results-sidebar .collapsible-sidebar[aria-expanded=false] .multibrand-filter-list {
    display: block;
  }
}
.search-results-sidebar .multibrand-filter-list--collapsed li:nth-child(1n+6) {
  display: none;
}
.search-results-sidebar .multibrand-filter-list .doc-count {
  color: var(--color-text-muted);
}
.search-results-sidebar .see-all-filters {
  background: none;
  border: none;
  cursor: pointer;
  display: block;
  padding: var(--spacing-1-5);
  color: rgba(34, 34, 34, 1);
}
.search-results-sidebar .see-all-filters[aria-hidden=true] {
  display: none;
}
.search-results-sidebar .see-all-filters:hover {
  text-decoration: underline;
}
.search-results-sidebar .see-all-filters::after {
  content: " ⌄";
  font-weight: bold;
}
/* Search Results Heading - Page title showing search query and result count */
.search-results-subheading {
  font-weight: 600;
  font-size: var(--font-size-3xl);
  font-family: "Moderat", 'Helvetica Neue', Arial, Helvetica, sans-serif;
  line-height: var(--line-height-tight);
  margin: 0;
  padding-bottom: var(--spacing-4);
  letter-spacing: -1.1px;
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .search-results-subheading {
    font-size: var(--font-size-4xl);
  }
}
  

/* Search Results List - Container for individual search result items */
.search-results-list {
  margin-bottom: 1.5625rem;
}
.search-results-list > li {
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid var(--color-border-default);
}
.search-results-list > li:first-child {
  border-top: 1px solid var(--color-border-default);
}
.search-results .no-results {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 4rem;
}
.search-results .no-results .headline {
  color: var(--color-text-dark);
  font-weight: 400;
  font-size: var(--font-size-lg);
  line-height: var(--spacing-3); /* 24px */
  letter-spacing: -0.45px;
}
.search-results .no-results .action-prompt {
  color: var(--color-text-secondary);
  font-weight: 400;
  font-size: var(--font-size-md);
  line-height: 1.25rem; /* 20px */
  letter-spacing: -0.154px;
}
.search-results .no-results .action-prompt a {
  color: rgba(34, 34, 34, 1);
}
.search-results .no-results .action-prompt a:visited {
  color: rgba(34, 34, 34, 1);
}

/* Search Result Item - Individual search result styling */
.search-result-title-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.search-result-title {
  font-family: "Moderat", 'Helvetica Neue', Arial, Helvetica, sans-serif;
  font-size: var(--font-size-xl);
  font-weight: 600;
  margin:0;
  margin-bottom: var(--spacing-0-5);
}
@media (min-width: 768px) { /* --breakpoint-sm */
  .search-result-title {
    font-size: var(--font-size-2xl);
  }
}

.search-result-title a {
  color: rgba(34, 34, 34, 1);
}

.search-result-votes, .search-result-meta-count {
  color: #555;
  font-size: var(--font-size-base);
}
.search-result-votes-icon, .search-result-meta-count-icon {
  color: rgba(34, 34, 34, 1);
  vertical-align: middle;
  width: 13px;
  height: 13px;
}
[dir=ltr] .search-result-votes, [dir=ltr] .search-result-meta-count {
  margin-left: var(--spacing-3);
}
[dir=rtl] .search-result-votes, [dir=rtl] .search-result-meta-count {
  margin-right: var(--spacing-3);
}
.search-result-meta-container {
  color: var(--color-text-muted);
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .search-result-meta-container {
    flex-direction: row;
    align-items: center;
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  .search-result-meta-container nav {
    flex: 1;
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  [dir=ltr] .search-result-meta-container .meta-data {
    margin-left: var(--spacing-3);
  }
}
@media (min-width: 1024px) { /* --breakpoint-md */
  [dir=rtl] .search-result-meta-container .meta-data {
    margin-right: var(--spacing-3);
  }
}
.search-result-meta-container .meta-data::after {
  content: none;
}
.search-result-breadcrumbs {
  margin: 0;
}

.search-result-breadcrumbs a {
  color: var(--color-text-dark);
}

.search-result-description {
  margin-top: var(--spacing-0-5);
  margin-bottom: 0;
  word-break: break-word;
  font-size: initial;
  color: var(--color-text-secondary);
}

/* By default use bold instead of italic to highlight */
.search-result-description em {
  font-style: italic;
  font-weight: bold;
  color: var(--color-text-primary);
  background: var(--color-brand-tertiary);
}

/* Add a yellow background for Chinese */
html[lang|=zh] .search-result-description em {
  font-style: normal;
  background: yellow;
}

/***** Notifications *****/
.notification {
  border: 1px solid;
  display: table;
  font-family: sans-serif;
  font-size: var(--font-size-sm);
  padding: 0.8125rem 0.9375rem; /* 13px 15px - using rem for accessibility */
  transition: height var(--transition-base) var(--ease-out);
  width: 100%;
  color: var(--color-gray-dark);
}

.notification a {
  color: var(--color-accent-blue);
}

.notification-inner {
  margin: 0 auto;
  padding: 0 var(--button-padding-x);
  max-width: 980px;
}

.notification-icon, .notification-inline.notification-error::before, .notification-text, .notification-dismiss {
  display: table-cell;
  vertical-align: middle;
}

.notification-text {
  padding: 0 0.9375rem;
  width: 100%;
}

.notification + .notification {
  margin-bottom: -1px;
  position: relative;
  top: -1px;
}

/* Error */
.notification-error {
  background: var(--color-notification-success-bg);
  border-color: var(--color-notification-success-border);
}

.notification-error .notification-icon::before, .notification-error .notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cg fill='none' stroke='%23555555'%3E%3Ccircle cx='5.5' cy='6.5' r='5'/%3E%3Cpath stroke-linecap='round' d='M5.5 3.5v3'/%3E%3C/g%3E%3Ccircle cx='5.5' cy='9' r='1' fill='%23555555'/%3E%3C/svg%3E");
}

/* Notice */
.notification-notice {
  background: var(--color-notification-info-bg);
  border-color: var(--color-notification-info-border);
}

.notification-notice .notification-icon::before, .notification-notice .notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cg fill='none' stroke='%23555555'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M3.5 6l2 2L9 4.5'/%3E%3Ccircle cx='6' cy='6' r='5.5'/%3E%3C/g%3E%3C/svg%3E");
}

/* Alert / Lock */
.notification-alert {
  color: var(--color-notification-warning-text);
  background: var(--color-notification-warning-bg);
  border-color: var(--color-notification-warning-border);
}

.notification-alert .notification-icon::before, .notification-alert .notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%23ad5e18' stroke-linecap='round' d='M5.06 1.27l-4.5 8.5c-.18.33.06.73.44.73h9c.38 0 .62-.4.44-.73l-4.5-8.5a.494.494 0 00-.88 0zM5.5 4v2'/%3E%3Ccircle cx='5.5' cy='8' r='.8' fill='%23ad5e18'/%3E%3C/svg%3E");
}

.notification-icon::before, .notification-inline.notification-error::before {
  background-size: cover;
  content: "";
  display: inline-block;
  height: 14px;
  width: 14px;
  vertical-align: middle;
}

/* Dismiss button */
.notification-dismiss, a.notification-dismiss {
  color: var(--color-gray-dark);
  cursor: pointer;
  opacity: 0.6;
  transition: opacity var(--transition-fast);
  text-decoration: none !important;
}

.notification-dismiss:hover {
  opacity: 1;
}

/* Inline notifications */
.notification-inline {
  border-radius: var(--radius-md);
  line-height: 0.875rem; /* 14px */
  margin-top: var(--spacing-0-5); /* 4px - closest match to 5px */
  padding: var(--spacing-0-5); /* 4px - closest match to 5px */
  position: relative;
  text-align: left;
  vertical-align: middle;
}
[dir=rtl] .notification-inline {
  text-align: right;
}
.notification-inline[aria-hidden=true] {
  display: none;
}
.notification-inline.notification-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' focusable='false' viewBox='0 0 12 12'%3E%3Cg fill='none' stroke='%23e35b66'%3E%3Ccircle cx='5.5' cy='6.5' r='5'/%3E%3Cpath stroke-linecap='round' d='M5.5 3.5v3'/%3E%3C/g%3E%3Ccircle cx='5.5' cy='9' r='1' fill='%23e35b66'/%3E%3C/svg%3E");
  margin: -2px var(--spacing-0-5) 0 0;
}
[dir=rtl] .notification-inline.notification-error::before {
  margin: 0 0 0 var(--spacing-0-5);
}
.notification-inline.notification-error {
  background-color: var(--color-notification-error-bg);
  border: 1px solid var(--color-notification-error-border);
  color: var(--color-notification-error-text);
}
.notification-inline.notification-large {
  padding: 0.8125rem 0.9375rem; /* 13px 15px - using rem for accessibility */
  margin-bottom: 1.5625rem;
}

.notification-left-aligned {
  text-align: left;
  padding-left: 0;
}

html[dir=rtl] .notification-left-aligned {
  text-align: right;
  padding-left: auto;
  padding-right: 0;
}

.dropdown {
  position: relative;
  display: inline-block;
}

.dropdown-toggle {
  cursor: pointer;
  background: none;
  border: 0;
  display: inline-block;
  padding: 0;
  text-align: initial;
  vertical-align: middle;
}
.dropdown-toggle:hover {
  text-decoration: none;
}
.dropdown-toggle > * {
  display: inline-block;
}
.dropdown-toggle[aria-expanded=true] + .dropdown-menu {
  display: block;
}

.dropdown-menu {
  background: var(--color-white);
  border: 1px solid var(--color-dropdown-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-xl);
  display: none;
  font-size: var(--font-size-md);
  font-style: normal;
  font-weight: normal;
  left: 0;
  margin-top: 1px;
  min-width: 170px;
  padding: var(--spacing-1-5) 0;
  position: absolute;
  text-align: left;
  z-index: var(--z-index-dropdown);
}
[dir=rtl] .dropdown-menu {
  text-align: right;
}
.dropdown-menu [role=separator] {
  border-bottom: 1px solid var(--color-border-default);
  margin: var(--spacing-0-5) 0;
}
.dropdown-menu [role=menuitem],
.dropdown-menu [role=menuitemradio] {
  color: var(--color-text-dark);
  cursor: pointer;
  display: block;
  padding: var(--spacing-1) var(--spacing-5) var(--spacing-1) var(--spacing-3);
  white-space: nowrap;
  background-color: transparent;
  border: 0;
  -webkit-appearance: none;
  text-align: start;
  line-height: inherit;
  width: 100%;
}
[dir=rtl] .dropdown-menu [role=menuitem],
[dir=rtl] .dropdown-menu [role=menuitemradio] {
  padding: var(--spacing-1) var(--spacing-2-5) var(--spacing-1) var(--spacing-5);
}
.dropdown-menu [role=menuitem]:hover, .dropdown-menu [role=menuitem]:focus,;
.dropdown-menu [role=menuitemradio]:hover,;
.dropdown-menu [role=menuitemradio]:focus {
  background: var(--color-shadow-hover);
  text-decoration: none;
  color: var(--color-text-dark);
}
.dropdown-menu [role=menuitem][aria-selected=true], .dropdown-menu [role=menuitem][aria-checked=true],
.dropdown-menu [role=menuitemradio][aria-selected=true],
.dropdown-menu [role=menuitemradio][aria-checked=true] {
  cursor: default;
}
.dropdown-menu [role=menuitem][aria-selected=true]::after, .dropdown-menu [role=menuitem][aria-checked=true]::after,;
.dropdown-menu [role=menuitemradio][aria-selected=true]::after,;
.dropdown-menu [role=menuitemradio][aria-checked=true]::after {
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M1 7l3 3 7-7'%3E%3C/path%3E%3C/svg%3E");
  display: inline-block;
  height: var(--spacing-1-5);
  margin-left: var(--spacing-1-5);
  width: var(--spacing-1-5);
}
[dir=rtl] .dropdown-menu [role=menuitem][aria-selected=true]::after, [dir=rtl] .dropdown-menu [role=menuitem][aria-checked=true]::after,;
[dir=rtl] .dropdown-menu [role=menuitemradio][aria-selected=true]::after,;
[dir=rtl] .dropdown-menu [role=menuitemradio][aria-checked=true]::after {
  margin-left: 0;
  margin-right: var(--spacing-1-5);
  float: left;
}
.dropdown-menu [role=menuitem][hidden], .dropdown-menu [role=menuitem][aria-hidden=true],
.dropdown-menu [role=menuitemradio][hidden],
.dropdown-menu [role=menuitemradio][aria-hidden=true] {
  display: none !important;
}

.dropdown-menu-end {
  left: auto;
  right: 0;
}

.dropdown-menu-top {
  bottom: 100%;
  margin-bottom: 1px;
}

[dir=rtl] .dropdown-menu {
  left: auto;
  right: 0;
  text-align: right;
}
[dir=rtl] .dropdown-menu-end {
  left: 0;
  right: auto;
}

.dropdown-chevron-icon {
  vertical-align: middle;
}

.content-tags > p {
  color: var(--color-text-secondary);
  margin-top: var(--spacing-4);
  margin-bottom: var(--spacing-0-5);
}
.content-tags-add-hint {
  color: var(--color-text-secondary);
  font-size: var(--font-size-md);
}

.content-tag-list {
  display: flex;
  flex-wrap: wrap;
  word-break: break-word;
}
.content-tag-list li {
  border-right: 1px solid var(--color-border-tag);
  margin-bottom: var(--spacing-0-5);
}
[dir=ltr] .content-tag-list li {
  padding-right: var(--spacing-1);
  margin-right: var(--spacing-1);
}
[dir=rtl] .content-tag-list li {
  padding-left: var(--spacing-1);
  margin-left: var(--spacing-1);
}
.content-tag-list li:last-child {
  border: none;
}

/***** WYSIWYG Editor *****/
#hc-wysiwyg {
  border: 1px solid var(--color-border-default);
}

/***** Upload Dropzone *****/
.upload-dropzone {
  border: 1px solid var(--color-border-default);
}

/***** Contacts Section *****/
.section.contacts {
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-6);
  display: block;
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  position: relative;
  min-height: auto;
  overflow: visible;
  padding: 0;
}
  

/* Mobile-first: Contacts section - allow image to bleed out on mobile */
.section.contacts {
  max-width: none;
  width: 100vw;
  margin-left: calc(-1 * var(--spacing-3));
  margin-right: calc(-1 * var(--spacing-3));
  overflow: hidden;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.contacts-image {
  min-width: 500px;
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  mix-blend-mode: multiply;
}

/* Desktop: Image sizing */
@media (min-width: 768px) {
  .section.contacts {
    max-width: none;
    min-height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  
  .contacts-image {
    width: 100%;
    max-width: 1112px;
    height: auto;
    object-fit: contain;
    mix-blend-mode: multiply;
  }
}

/* Desktop: Reset mobile full-width and allow image to extend beyond container */
@media (min-width: 768px) {
  .section.contacts {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    overflow: visible;
  }
  
  .container .section.contacts {
    margin-left: calc(-1 * var(--spacing-6));
    margin-right: calc(-1 * var(--spacing-6));
    width: calc(100% + 2 * var(--spacing-6));
  }
  
  .contacts-image {
    min-width: auto;
  }
}

.contacts-popup {
  background-color: var(--color-bg-body);
  padding: 0 var(--spacing-3);
  max-width: 600px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3);
}

@media (min-width: 768px) {
  .contacts-popup {
    background-color: var(--color-white);
    padding: var(--spacing-6);
  }
}

.contacts-text {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
  text-align: center;
}

.contacts-text h3 {
  font-size: var(--font-size-2xl);
  font-weight: 600;
  color: var(--color-text-dark);
  margin: 0;
}

.contacts-text p {
  font-size: var(--font-size-base);
  color: var(--color-text-dark);
  margin: 0;
  line-height: var(--line-height-relaxed);
}

.contacts-buttons {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}

@media (min-width: 768px) {
  .contacts-buttons {
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
  }
}

/* Contacts buttons layout - equal width buttons with minimum width */
.contacts-buttons .button {
  min-width: 156px;
}
