/* ==========================================================================
   Product Portfolio - EFlex Training Platform
   Styles for the Product Portfolio section (landing, navigation, explorer)
   Uses design tokens from variables.css
   ========================================================================== */


/* ==========================================================================
   1. Landing Page
   ========================================================================== */

.landing-wrapper {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  padding: var(--space-5) var(--space-4);
}

.landing-header {
  text-align: center;
  margin-bottom: var(--space-6);
}

.landing-header img {
  height: 40px;
  opacity: 0.9;
}

.landing-header h1 {
  color: #ffffff;
  font-family: var(--font-family);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  margin-top: var(--space-3);
  letter-spacing: -0.02em;
}

.landing-header p {
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--font-size-base);
  margin-top: var(--space-2);
}

.landing-cards {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  max-width: 800px;
  width: 100%;
}

.landing-card {
  background: var(--bg-primary);
  border-radius: var(--border-radius-xl);
  padding: 40px;
  min-width: 320px;
  flex: 1;
  text-align: center;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.landing-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-xl);
}

.landing-card h3 {
  font-size: 20px;
  font-weight: var(--font-weight-semibold);
  color: var(--text-heading);
  margin-bottom: var(--space-1);
  font-family: var(--font-family);
}

.landing-card p {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-4);
  line-height: var(--line-height-base);
}

.landing-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--bg-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-3);
  font-size: 20px;
}

.landing-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.3px;
  margin-bottom: var(--space-3);
}

.landing-badge-secure {
  background: var(--secondary-light);
  color: var(--secondary);
}

.landing-badge-open {
  background: var(--success-light);
  color: var(--success);
}

.landing-btn {
  display: block;
  width: 100%;
  height: 44px;
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  font-family: var(--font-family);
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast);
  border: 2px solid transparent;
  text-align: center;
  line-height: 40px;
  text-decoration: none;
}

.landing-btn-primary {
  background: var(--accent);
  color: #ffffff;
  border-color: var(--accent);
}

.landing-btn-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.landing-btn-outline {
  background: transparent;
  color: var(--text-heading);
  border-color: var(--border-subtle);
}

.landing-btn-outline:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.landing-footer {
  text-align: center;
  margin-top: var(--space-6);
  color: rgba(255, 255, 255, 0.5);
  font-size: var(--font-size-sm);
  font-style: italic;
}


/* ==========================================================================
   2. Portfolio Top Navigation
   ========================================================================== */

.portfolio-topnav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: 56px;
  background: var(--primary-dark);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-4);
  font-family: var(--font-family);
}

.portfolio-topnav-logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.portfolio-topnav-logo img {
  height: 24px;
  opacity: 0.9;
}

.portfolio-back-link {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: color var(--transition-fast);
  white-space: nowrap;
}

.portfolio-back-link:hover {
  color: #ffffff;
}

body.portfolio-active {
  padding-top: 56px;
}


/* ==========================================================================
   3. Product Tabs
   ========================================================================== */

.portfolio-tabs {
  display: flex;
  align-items: center;
  gap: 0;
}

.portfolio-tab {
  padding: var(--space-3) var(--space-4);
  color: rgba(255, 255, 255, 0.7);
  font-size: 14px;
  font-weight: var(--font-weight-medium);
  font-family: var(--font-family);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color var(--transition-fast), border-color var(--transition-fast);
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
}

.portfolio-tab.active {
  color: #ffffff;
  border-bottom-color: var(--accent);
}

.portfolio-tab.disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.portfolio-tab:hover:not(.disabled):not(.active) {
  color: rgba(255, 255, 255, 0.9);
}


/* ==========================================================================
   4. Feature Pills
   ========================================================================== */

.portfolio-pills-bar {
  background: var(--bg-primary);
  border-bottom: 1px solid var(--border-subtle);
  position: sticky;
  top: 56px;
  z-index: 99;
}

.portfolio-pills {
  background: var(--bg-primary);
  padding: 12px var(--space-4);
  display: flex;
  gap: var(--space-2);
  overflow-x: auto;
  flex-wrap: nowrap;
  -webkit-overflow-scrolling: touch;
}

/* Hide scrollbar but allow scrolling */
.portfolio-pills::-webkit-scrollbar {
  display: none;
}

.portfolio-pills {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.portfolio-pill {
  padding: 6px 16px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: var(--font-weight-medium);
  font-family: var(--font-family);
  background: #f0f1f3;
  color: var(--text-body);
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.portfolio-pill.active {
  background: var(--accent);
  color: #ffffff;
}

.portfolio-pill:hover:not(.active) {
  background: #e4e6e8;
}


/* ==========================================================================
   5. Portfolio Content Area
   ========================================================================== */

.portfolio-content-wrapper {
  padding-top: 56px; /* account for fixed topnav */
  background: var(--bg-secondary);
  min-height: 100vh;
}

.portfolio-content {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-6) var(--space-5);
  min-height: calc(100vh - 56px - 52px);
}

.portfolio-content h2 {
  margin-bottom: var(--space-2);
}

.portfolio-content h3 {
  margin-top: var(--space-5);
  margin-bottom: var(--space-3);
}

.portfolio-content p {
  margin-bottom: var(--space-3);
  line-height: var(--line-height-base);
}

/* Fixation Toggle (Cemented / Cementless) */
.fixation-toggle {
  display: flex;
  gap: 0;
  margin-bottom: var(--space-4);
  border: 1px solid var(--border-subtle);
  border-radius: var(--border-radius);
  overflow: hidden;
  width: fit-content;
}

.fixation-btn {
  padding: 8px 20px;
  font-size: 13px;
  font-weight: var(--font-weight-medium);
  font-family: var(--font-family);
  border: none;
  background: var(--bg-primary);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
  border-right: 1px solid var(--border-subtle);
  white-space: nowrap;
}

.fixation-btn:last-child {
  border-right: none;
}

.fixation-btn.active {
  background: var(--primary);
  color: #ffffff;
}

.fixation-btn:hover:not(.active) {
  background: var(--bg-secondary);
  color: var(--text-heading);
}

/* System Comparison Cards */
.system-comparison {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.system-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--border-radius-lg);
  padding: var(--space-4);
}

.system-card h4 {
  margin-top: 0;
  margin-bottom: var(--space-2);
  color: var(--primary);
  font-size: 16px;
}

.system-card-label {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-2);
}

.system-card-label.cemented {
  background: #e8f0fa;
  color: var(--primary);
}

.system-card-label.cementless {
  background: #e8f4f8;
  color: var(--accent);
}

.system-card dl {
  margin: 0;
  font-size: 13px;
}

.system-card dt {
  color: var(--text-secondary);
  font-weight: var(--font-weight-medium);
  margin-top: var(--space-2);
  font-size: 12px;
}

.system-card dd {
  margin-left: 0;
  color: var(--text-heading);
  font-weight: var(--font-weight-semibold);
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.system-card-note {
  font-size: 12px;
  color: var(--text-secondary);
  font-style: italic;
  margin-top: var(--space-2);
  margin-bottom: 0;
}

/* Size button cemented-only note */
.size-btn-note {
  font-size: 7px;
  opacity: 0.7;
  margin-top: 1px;
  line-height: 1;
}

/* Bearing type section headers in grid */
.bearing-type-section-header {
  grid-column: 1 / -1;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-secondary);
  font-weight: var(--font-weight-semibold);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border-subtle);
  margin-top: var(--space-2);
}

.bearing-type-section-header:first-child {
  border-top: none;
  margin-top: 0;
  padding-top: 0;
}

@media (max-width: 768px) {
  .system-comparison {
    grid-template-columns: 1fr;
  }
  .fixation-toggle {
    width: 100%;
  }
  .fixation-btn {
    flex: 1;
    text-align: center;
    font-size: 12px;
    padding: 8px 12px;
  }
}


/* ==========================================================================
   6. Compatibility Explorer
   ========================================================================== */

.compat-section {
  font-family: var(--font-family);
}

.compat-sizes,
.compat-size-selector {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-bottom: var(--space-4);
}

.size-btn {
  width: 64px;
  height: 64px;
  border-radius: var(--border-radius-lg);
  border: 3px solid transparent;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.size-btn:hover {
  transform: scale(1.05);
}

.size-btn.active {
  border-color: #ffffff;
  box-shadow: 0 0 0 2px var(--primary);
}

.size-btn .size-num {
  font-size: 16px;
  font-weight: var(--font-weight-bold);
  color: #ffffff;
  line-height: 1.2;
}

.size-btn .size-num.dark-text {
  color: var(--text-heading);
}

.size-btn .size-name {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  opacity: 0.8;
  color: #ffffff;
  line-height: 1.2;
}

.size-btn .size-name.dark-text {
  color: var(--text-body);
}

.compat-results {
  background: var(--bg-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--border-radius-lg);
  padding: var(--space-4);
}

.compat-results-empty {
  text-align: center;
  color: var(--text-secondary);
  padding: 40px;
  font-size: var(--font-size-sm);
}

.compat-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.compat-dims {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-4);
}

.compat-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
}

.compat-detail {
  background: var(--bg-secondary);
  border-radius: var(--border-radius);
  padding: var(--space-4);
}

.compat-detail h4 {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
  margin-top: 0;
  font-weight: var(--font-weight-semibold);
}

.compat-detail p {
  font-size: var(--font-size-sm);
  color: var(--text-body);
  margin-bottom: var(--space-1);
}

.compat-tray-list,
.compat-bearing-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: var(--font-weight-medium);
}

.badge-primary {
  background: #e8f0fa;
  color: var(--primary);
}

.badge-secondary {
  background: #e8f4f8;
  color: var(--accent);
}

.badge-lg {
  padding: 8px 20px;
  font-size: 15px;
  font-weight: var(--font-weight-bold);
  border-radius: var(--border-radius);
}

.compat-insert-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.compat-placeholder {
  text-align: center;
  color: var(--text-secondary);
  padding: var(--space-5);
}

/* Tray list in compatibility results */
.compat-tray-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* Static reference section below the dynamic results */
.compat-static-ref {
  margin-top: var(--space-5);
  padding: var(--space-4);
  background: var(--bg-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--border-radius-lg);
}

.compat-static-ref h3 {
  margin-top: 0;
  margin-bottom: var(--space-3);
  font-size: var(--font-size-base);
  color: var(--text-heading);
}

.compat-ref-section {
  margin-bottom: var(--space-3);
}

.compat-ref-section:last-child {
  margin-bottom: 0;
}

.compat-ref-section h4 {
  margin-top: 0;
  margin-bottom: var(--space-2);
}

.compat-ref-note {
  font-size: 12px;
  color: var(--text-secondary);
  margin-top: var(--space-2);
  margin-bottom: 0;
}

.bearing-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.bearing-badge {
  padding: 4px 12px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: var(--font-weight-medium);
  background: #e8f4f8;
  color: var(--accent);
}

/* Bearing type cards grid (sizing reference page) */
.bearing-type-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.bearing-type-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--border-radius-lg);
  padding: var(--space-4);
  transition: box-shadow var(--transition-fast);
}

.bearing-type-card:hover {
  box-shadow: var(--shadow-sm);
}

.bearing-type-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.bearing-type-code {
  font-size: 18px;
  font-weight: var(--font-weight-bold);
  color: var(--accent);
  font-family: var(--font-family);
}

.bearing-type-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-heading);
}

.bearing-type-desc {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  line-height: var(--line-height-base);
  margin: 0;
}


/* ==========================================================================
   7. Color Legend
   ========================================================================== */

.color-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  padding: var(--space-3);
  background: var(--bg-primary);
  border-radius: var(--border-radius);
  border: 1px solid var(--border-subtle);
  margin-bottom: var(--space-4);
}

.color-swatch {
  display: flex;
  align-items: center;
  gap: 6px;
}

.color-swatch-dot {
  width: 20px;
  height: 20px;
  border-radius: var(--border-radius-sm);
  flex-shrink: 0;
}

.color-swatch-label {
  font-size: 12px;
  color: var(--text-body);
  white-space: nowrap;
}


/* ==========================================================================
   8. Tray Catalog
   ========================================================================== */

.tray-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.tray-part-number {
  font-size: 12px;
  color: var(--text-secondary);
  font-family: var(--font-mono);
}

.tray-image-wrapper {
  margin-top: var(--space-4);
  text-align: center;
}

.tray-image {
  max-width: 100%;
  height: auto;
  border-radius: var(--border-radius);
  border: 1px solid var(--border-subtle);
}

.tray-parts-table {
  width: 100%;
}

.tray-description {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-3);
}


/* ==========================================================================
   9. Implant Banks
   ========================================================================== */

/* Ensure bank tabs don't scroll on desktop */
#portfolio-banks-tabs .tab-list {
  flex-wrap: wrap;
  overflow-x: visible;
}

#portfolio-banks-tabs .tab-button {
  white-space: nowrap;
  font-size: var(--font-size-sm);
}

.bank-category {
  margin-bottom: var(--space-5);
}

.bank-note {
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-2);
}

.bank-category h4 {
  font-size: 14px;
  font-weight: var(--font-weight-semibold);
  color: var(--text-heading);
  margin-bottom: var(--space-2);
}

.bank-table {
  width: 100%;
}

.bank-warning {
  /* Reuses existing .callout.warning styles from components.css */
}


/* ==========================================================================
   10. Sizing Tables & Unit Toggle
   ========================================================================== */

.spec-table-container {
  overflow-x: auto;
  margin-bottom: var(--space-4);
}

.portfolio-content .spec-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.portfolio-content .spec-table th {
  background: var(--primary);
  color: #ffffff;
  padding: 10px 16px;
  text-align: left;
  font-weight: var(--font-weight-semibold);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.portfolio-content .spec-table td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border-subtle);
  color: var(--text-body);
}

.portfolio-content .spec-table tbody tr:hover {
  background: rgba(0, 124, 159, 0.04);
}

.unit-toggle {
  display: flex;
  gap: 0;
  margin-bottom: var(--space-2);
  justify-content: flex-end;
}

.unit-toggle button {
  padding: 4px 14px;
  font-size: 12px;
  font-weight: var(--font-weight-medium);
  font-family: var(--font-family);
  border: 1px solid var(--border-subtle);
  background: var(--bg-primary);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.unit-toggle button:first-child {
  border-radius: 4px 0 0 4px;
}

.unit-toggle button:last-child {
  border-radius: 0 4px 4px 0;
  border-left: none;
}

.unit-toggle button.active {
  background: var(--accent);
  color: #ffffff;
  border-color: var(--accent);
}

/* Coming soon placeholder */
.portfolio-coming-soon {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--text-secondary);
}

.portfolio-coming-soon h2 {
  color: var(--text-heading);
  margin-bottom: var(--space-2);
}

.coming-soon-icon {
  font-size: 48px;
  margin-bottom: var(--space-3);
}

.coming-soon-badge {
  font-size: 10px;
  opacity: 0.5;
  margin-left: var(--space-1);
}

/* Accordion fixes for portfolio context */
.portfolio-content .accordion-item {
  border: 1px solid var(--border-subtle);
  border-radius: var(--border-radius);
  margin-bottom: var(--space-2);
  overflow: hidden;
}

.portfolio-content .accordion-header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  background: var(--bg-primary);
  border: none;
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  font-family: var(--font-family);
  color: var(--text-heading);
  text-align: left;
}

.portfolio-content .accordion-header:hover {
  background: var(--bg-secondary);
}

.portfolio-content .accordion-chevron {
  transition: transform var(--transition-fast);
  color: var(--text-secondary);
  flex-shrink: 0;
}

.portfolio-content .accordion-item.active .accordion-chevron {
  transform: rotate(180deg);
}

.portfolio-content .accordion-content {
  display: none;
  padding: 0 var(--space-4) var(--space-4);
}

.portfolio-content .accordion-item.active .accordion-content {
  display: block;
}

/* Tab fixes for portfolio context */
.portfolio-content .tab-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-bottom: 2px solid var(--border-subtle);
  margin-bottom: var(--space-4);
}

.portfolio-content .tab-button {
  padding: var(--space-2) var(--space-4);
  border: none;
  background: none;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-family);
  color: var(--text-secondary);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.portfolio-content .tab-button.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.portfolio-content .tab-button:hover:not(.active) {
  color: var(--text-heading);
}

.portfolio-content .tab-panel {
  display: none;
}

.portfolio-content .tab-panel.active {
  display: block;
}

/* Callout in portfolio context */
.portfolio-content .callout {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--border-radius);
  margin-bottom: var(--space-4);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
}

.portfolio-content .callout-warning {
  background: #fff8e6;
  border-left: 4px solid #FF8B00;
}

.portfolio-content .callout-info {
  background: #e8f4f8;
  border-left: 4px solid var(--accent);
}

.portfolio-content .callout-title {
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-1);
}


/* ==========================================================================
   11. Responsive Breakpoints
   ========================================================================== */

@media (max-width: 1024px) {
  .portfolio-content {
    padding: var(--space-4) var(--space-3);
  }
}

@media (max-width: 768px) {
  .landing-cards {
    flex-direction: column;
    align-items: center;
  }

  .landing-card {
    min-width: 0;
    width: 100%;
    max-width: 400px;
    padding: var(--space-5) var(--space-4);
  }

  .landing-header h1 {
    font-size: var(--font-size-2xl);
  }

  .size-btn {
    width: 52px;
    height: 52px;
  }

  .size-btn .size-num {
    font-size: 14px;
  }

  .size-btn .size-name {
    font-size: 8px;
  }

  .compat-detail {
    grid-template-columns: 1fr;
  }

  .portfolio-tabs {
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .portfolio-tab {
    padding: var(--space-3) var(--space-3);
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .portfolio-pills {
    padding: var(--space-2) 12px;
  }

  .portfolio-pill {
    font-size: 11px;
    padding: 5px 12px;
  }

  .landing-wrapper {
    padding: var(--space-3) var(--space-3);
  }

  .landing-card {
    padding: var(--space-4) var(--space-3);
  }

  .portfolio-content {
    padding: var(--space-3) var(--space-2);
  }
}
