banhaten 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (201) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +361 -0
  3. package/banhaten.config.example.json +13 -0
  4. package/package.json +59 -0
  5. package/registry/assets/activity-feed-avatar.png +0 -0
  6. package/registry/assets/avatars/avatar-01.jpg +0 -0
  7. package/registry/assets/avatars/avatar-02.jpg +0 -0
  8. package/registry/assets/avatars/avatar-03.jpg +0 -0
  9. package/registry/assets/avatars/avatar-04.jpg +0 -0
  10. package/registry/assets/avatars/avatar-05.jpg +0 -0
  11. package/registry/assets/avatars/avatar-06.jpg +0 -0
  12. package/registry/assets/avatars/avatar-07.jpg +0 -0
  13. package/registry/assets/avatars/avatar-08.jpg +0 -0
  14. package/registry/assets/avatars/avatar-09.jpg +0 -0
  15. package/registry/assets/avatars/avatar-10.jpg +0 -0
  16. package/registry/assets/avatars/avatar-11.jpg +0 -0
  17. package/registry/assets/avatars/avatar-12.jpg +0 -0
  18. package/registry/assets/avatars/avatar-13.jpg +0 -0
  19. package/registry/assets/avatars/avatar-14.jpg +0 -0
  20. package/registry/assets/avatars/avatar-15.jpg +0 -0
  21. package/registry/assets/avatars/avatar-16.jpg +0 -0
  22. package/registry/assets/avatars/avatar-17.jpg +0 -0
  23. package/registry/assets/avatars/avatar-18.jpg +0 -0
  24. package/registry/assets/avatars/avatar-19.jpg +0 -0
  25. package/registry/assets/avatars/avatar-20.jpg +0 -0
  26. package/registry/assets/avatars/avatar-21.jpg +0 -0
  27. package/registry/assets/avatars/avatar-22.jpg +0 -0
  28. package/registry/assets/avatars/avatar-23.jpg +0 -0
  29. package/registry/assets/avatars/avatar-24.jpg +0 -0
  30. package/registry/assets/avatars/avatar-25.jpg +0 -0
  31. package/registry/assets/avatars/avatar-26.jpg +0 -0
  32. package/registry/assets/avatars/avatar-27.jpg +0 -0
  33. package/registry/assets/avatars/avatar-28.jpg +0 -0
  34. package/registry/assets/avatars/avatar-29.jpg +0 -0
  35. package/registry/assets/avatars/avatar-30.jpg +0 -0
  36. package/registry/assets/avatars/avatar-31.jpg +0 -0
  37. package/registry/assets/avatars/avatar-32.jpg +0 -0
  38. package/registry/assets/avatars/avatar-33.jpg +0 -0
  39. package/registry/assets/avatars/avatar-34.jpg +0 -0
  40. package/registry/assets/avatars/avatar-35.jpg +0 -0
  41. package/registry/assets/image-assets.json +744 -0
  42. package/registry/assets/images/art-01.jpg +0 -0
  43. package/registry/assets/images/art-02.jpg +0 -0
  44. package/registry/assets/images/art-03.jpg +0 -0
  45. package/registry/assets/images/art-04.jpg +0 -0
  46. package/registry/assets/images/art-05.jpg +0 -0
  47. package/registry/assets/images/art-06.jpg +0 -0
  48. package/registry/assets/images/art-07.jpg +0 -0
  49. package/registry/assets/images/art-08.jpg +0 -0
  50. package/registry/assets/images/art-09.jpg +0 -0
  51. package/registry/assets/images/art-10.jpg +0 -0
  52. package/registry/assets/images/art-11.jpg +0 -0
  53. package/registry/assets/images/art-12.jpg +0 -0
  54. package/registry/assets/images/art-13.jpg +0 -0
  55. package/registry/assets/images/art-14.jpg +0 -0
  56. package/registry/assets/images/art-15.jpg +0 -0
  57. package/registry/assets/images/art-16.jpg +0 -0
  58. package/registry/assets/images/art-17.jpg +0 -0
  59. package/registry/assets/images/art-18.jpg +0 -0
  60. package/registry/assets/images/art-19.jpg +0 -0
  61. package/registry/assets/images/art-20.jpg +0 -0
  62. package/registry/assets/images/art-21.jpg +0 -0
  63. package/registry/assets/images/art-22.jpg +0 -0
  64. package/registry/assets/images/art-23.jpg +0 -0
  65. package/registry/assets/images/art-24.jpg +0 -0
  66. package/registry/assets/images/art-25.jpg +0 -0
  67. package/registry/assets/images/art-26.jpg +0 -0
  68. package/registry/assets/images/art-27.jpg +0 -0
  69. package/registry/assets/images/nature-01.jpg +0 -0
  70. package/registry/assets/images/nature-02.jpg +0 -0
  71. package/registry/assets/images/nature-03.jpg +0 -0
  72. package/registry/assets/images/nature-04.jpg +0 -0
  73. package/registry/assets/images/nature-05.jpg +0 -0
  74. package/registry/assets/images/nature-06.jpg +0 -0
  75. package/registry/assets/images/nature-07.jpg +0 -0
  76. package/registry/assets/images/nature-08.jpg +0 -0
  77. package/registry/assets/images/nature-09.jpg +0 -0
  78. package/registry/assets/images/nature-10.jpg +0 -0
  79. package/registry/assets/images/nature-11.jpg +0 -0
  80. package/registry/assets/images/nature-12.jpg +0 -0
  81. package/registry/assets/images/nature-13.jpg +0 -0
  82. package/registry/assets/images/nature-14.jpg +0 -0
  83. package/registry/assets/images/nature-15.jpg +0 -0
  84. package/registry/assets/images/nature-16.jpg +0 -0
  85. package/registry/assets/images/nature-17.jpg +0 -0
  86. package/registry/assets/images/nature-18.jpg +0 -0
  87. package/registry/assets/images/nature-19.jpg +0 -0
  88. package/registry/assets/images/nature-20.jpg +0 -0
  89. package/registry/components/accordion.tsx +119 -0
  90. package/registry/components/alert.tsx +282 -0
  91. package/registry/components/attribute.tsx +452 -0
  92. package/registry/components/avatar.tsx +142 -0
  93. package/registry/components/badge.tsx +567 -0
  94. package/registry/components/button-group.tsx +246 -0
  95. package/registry/components/button.tsx +102 -0
  96. package/registry/components/card.tsx +613 -0
  97. package/registry/components/checkbox.tsx +244 -0
  98. package/registry/components/date-picker.tsx +1143 -0
  99. package/registry/components/divider.tsx +82 -0
  100. package/registry/components/expanded/ActivityFeed.tsx +226 -0
  101. package/registry/components/expanded/Banner.tsx +145 -0
  102. package/registry/components/expanded/BannerBoard.tsx +225 -0
  103. package/registry/components/expanded/Breadcrumbs.tsx +156 -0
  104. package/registry/components/expanded/CatalogComponentsShowcase.tsx +211 -0
  105. package/registry/components/expanded/CatalogDivider.tsx +48 -0
  106. package/registry/components/expanded/CatalogTag.tsx +92 -0
  107. package/registry/components/expanded/CommandBar.tsx +406 -0
  108. package/registry/components/expanded/FileUpload.tsx +231 -0
  109. package/registry/components/expanded/IconExplorer.tsx +612 -0
  110. package/registry/components/expanded/OnboardingStepListItem.tsx +67 -0
  111. package/registry/components/expanded/PageHeader.tsx +184 -0
  112. package/registry/components/expanded/Slideout.tsx +514 -0
  113. package/registry/components/expanded/Steps.tsx +266 -0
  114. package/registry/components/expanded/Table.tsx +1014 -0
  115. package/registry/components/expanded/Tabs.tsx +86 -0
  116. package/registry/components/expanded/Timeline.tsx +235 -0
  117. package/registry/components/expanded/TimelineShowcase.tsx +158 -0
  118. package/registry/components/expanded/activityFeed.css +292 -0
  119. package/registry/components/expanded/banner.css +312 -0
  120. package/registry/components/expanded/breadcrumbs.css +140 -0
  121. package/registry/components/expanded/catalogComponentsShowcase.css +87 -0
  122. package/registry/components/expanded/commandBar.css +473 -0
  123. package/registry/components/expanded/divider.css +75 -0
  124. package/registry/components/expanded/fileUpload.css +228 -0
  125. package/registry/components/expanded/iconExplorer.css +764 -0
  126. package/registry/components/expanded/iconPacks.ts +866 -0
  127. package/registry/components/expanded/onboardingStepListItem.css +126 -0
  128. package/registry/components/expanded/pageHeader.css +287 -0
  129. package/registry/components/expanded/slideout.css +955 -0
  130. package/registry/components/expanded/steps.css +329 -0
  131. package/registry/components/expanded/table.css +607 -0
  132. package/registry/components/expanded/tabs.css +197 -0
  133. package/registry/components/expanded/tag.css +148 -0
  134. package/registry/components/expanded/timeline.css +282 -0
  135. package/registry/components/input-content.ts +106 -0
  136. package/registry/components/input.tsx +866 -0
  137. package/registry/components/menu.tsx +758 -0
  138. package/registry/components/modal.tsx +799 -0
  139. package/registry/components/pagination.tsx +543 -0
  140. package/registry/components/progress-slider.tsx +216 -0
  141. package/registry/components/progress.tsx +367 -0
  142. package/registry/components/radio-card.tsx +654 -0
  143. package/registry/components/radio-group.tsx +570 -0
  144. package/registry/components/select-content.tsx +313 -0
  145. package/registry/components/select.tsx +871 -0
  146. package/registry/components/slider.tsx +380 -0
  147. package/registry/components/social-button.tsx +360 -0
  148. package/registry/components/spinner.tsx +31 -0
  149. package/registry/components/tag.tsx +423 -0
  150. package/registry/components/textarea.tsx +625 -0
  151. package/registry/components/toggle.tsx +272 -0
  152. package/registry/components/toolbar.tsx +467 -0
  153. package/registry/components/tooltip.tsx +427 -0
  154. package/registry/examples/accordion-demo.tsx +34 -0
  155. package/registry/examples/alert-demo.tsx +14 -0
  156. package/registry/examples/attribute-demo.tsx +65 -0
  157. package/registry/examples/avatar-demo.tsx +74 -0
  158. package/registry/examples/badge-demo.tsx +53 -0
  159. package/registry/examples/button-demo.tsx +83 -0
  160. package/registry/examples/button-group-demo.tsx +42 -0
  161. package/registry/examples/card-demo.tsx +48 -0
  162. package/registry/examples/checkbox-demo.tsx +67 -0
  163. package/registry/examples/date-picker-demo.tsx +74 -0
  164. package/registry/examples/divider-demo.tsx +17 -0
  165. package/registry/examples/expanded/activity-feed-demo.tsx +22 -0
  166. package/registry/examples/expanded/banner-demo.tsx +23 -0
  167. package/registry/examples/expanded/catalog-components-demo.tsx +5 -0
  168. package/registry/examples/expanded/command-bar-demo.tsx +10 -0
  169. package/registry/examples/expanded/icons-demo.tsx +5 -0
  170. package/registry/examples/expanded/onboarding-step-demo.tsx +11 -0
  171. package/registry/examples/expanded/page-header-demo.tsx +19 -0
  172. package/registry/examples/expanded/slideout-demo.tsx +15 -0
  173. package/registry/examples/expanded/steps-demo.tsx +18 -0
  174. package/registry/examples/expanded/tabs-demo.tsx +13 -0
  175. package/registry/examples/expanded/timeline-demo.tsx +18 -0
  176. package/registry/examples/input-demo.tsx +87 -0
  177. package/registry/examples/menu-demo.tsx +109 -0
  178. package/registry/examples/modal-demo.tsx +16 -0
  179. package/registry/examples/pagination-demo.tsx +17 -0
  180. package/registry/examples/progress-demo.tsx +37 -0
  181. package/registry/examples/progress-slider-demo.tsx +29 -0
  182. package/registry/examples/radio-card-demo.tsx +51 -0
  183. package/registry/examples/radio-group-demo.tsx +62 -0
  184. package/registry/examples/select-demo.tsx +73 -0
  185. package/registry/examples/slider-demo.tsx +31 -0
  186. package/registry/examples/social-button-demo.tsx +51 -0
  187. package/registry/examples/tag-demo.tsx +29 -0
  188. package/registry/examples/textarea-demo.tsx +79 -0
  189. package/registry/examples/toggle-demo.tsx +59 -0
  190. package/registry/examples/toolbar-demo.tsx +80 -0
  191. package/registry/examples/tooltip-demo.tsx +115 -0
  192. package/registry/hooks/use-direction.ts +27 -0
  193. package/registry/index.json +1213 -0
  194. package/registry/styles/globals.css +4600 -0
  195. package/registry/utils/cn.ts +6 -0
  196. package/src/cli/index.js +826 -0
  197. package/tokens/Color mode.zip +0 -0
  198. package/tokens/Numbers.zip +0 -0
  199. package/tokens/Radius.zip +0 -0
  200. package/tokens/Theme.zip +0 -0
  201. package/tokens/banhaten.tokens.json +5525 -0
@@ -0,0 +1,126 @@
1
+ .ds-onboarding-step {
2
+ --onboarding-step-bg-raised: var(--bh-bg-raised);
3
+ --onboarding-step-border-brand-strong: var(--bh-border-brand-strong);
4
+ --onboarding-step-border-default: var(--bh-border-default);
5
+ --onboarding-step-content-brand: var(--bh-content-brand-default);
6
+ --onboarding-step-content-default: var(--bh-content-default);
7
+ --onboarding-step-content-subtle: var(--bh-content-subtle);
8
+ --onboarding-step-content-success: var(--bh-content-success-default);
9
+ --onboarding-step-radius: var(--bh-control-default);
10
+ --onboarding-step-space-md: var(--bh-space-md-8);
11
+ --onboarding-step-space-lg: var(--bh-space-lg-10);
12
+ --onboarding-step-space-xl: var(--bh-space-xl-12);
13
+ --onboarding-step-width: calc(var(--bh-space-17xl-288) - var(--bh-space-md-8));
14
+ --onboarding-step-height: var(--bh-space-7xl-40);
15
+ --onboarding-step-line-wrap-size: var(--bh-space-5xl-24);
16
+ --onboarding-step-check-size: var(--bh-space-4xl-20);
17
+ --onboarding-step-line-width: var(--bh-space-xxs-2);
18
+ --onboarding-step-line-offset: calc(-1 * var(--bh-space-md-8));
19
+ --onboarding-step-line-segment-height: calc(var(--bh-space-2xl-14) - var(--bh-space-xxxs-1));
20
+ --onboarding-step-shadow: var(--shadow-component-default);
21
+
22
+ box-sizing: border-box;
23
+ position: relative;
24
+ display: flex;
25
+ align-items: center;
26
+ gap: var(--onboarding-step-space-lg);
27
+ width: var(--onboarding-step-width);
28
+ height: var(--onboarding-step-height);
29
+ padding: var(--onboarding-step-space-md) var(--onboarding-step-space-xl);
30
+ border: var(--bh-space-xxxs-1) solid transparent;
31
+ border-radius: var(--onboarding-step-radius);
32
+ color: var(--onboarding-step-content-default);
33
+ background: transparent;
34
+ font-family: var(--bh-font-family);
35
+ font-size: var(--bh-text-body-md-medium-font-size);
36
+ font-style: normal;
37
+ font-weight: var(--bh-text-body-md-medium-font-weight);
38
+ line-height: var(--bh-text-body-md-medium-line-height);
39
+ letter-spacing: var(--bh-text-body-md-medium-letter-spacing);
40
+ }
41
+
42
+ .ds-onboarding-step *,
43
+ .ds-onboarding-step *::before,
44
+ .ds-onboarding-step *::after {
45
+ box-sizing: border-box;
46
+ }
47
+
48
+ .ds-onboarding-step--active {
49
+ border-color: var(--onboarding-step-border-default);
50
+ color: var(--onboarding-step-content-brand);
51
+ background: var(--onboarding-step-bg-raised);
52
+ box-shadow: var(--onboarding-step-shadow);
53
+ }
54
+
55
+ .ds-onboarding-step--inactive {
56
+ color: var(--onboarding-step-content-subtle);
57
+ }
58
+
59
+ .ds-onboarding-step--rtl {
60
+ font-family: var(--bh-font-family);
61
+ }
62
+
63
+ .ds-onboarding-step__line-wrap {
64
+ position: relative;
65
+ display: flex;
66
+ flex: 0 0 var(--onboarding-step-line-wrap-size);
67
+ align-items: center;
68
+ justify-content: center;
69
+ width: var(--onboarding-step-line-wrap-size);
70
+ height: var(--onboarding-step-line-wrap-size);
71
+ color: var(--onboarding-step-content-success);
72
+ }
73
+
74
+ .ds-onboarding-step__label {
75
+ flex: 1 0 0;
76
+ min-width: 0;
77
+ color: currentColor;
78
+ word-break: break-word;
79
+ }
80
+
81
+ .ds-onboarding-step--rtl .ds-onboarding-step__label {
82
+ text-align: right;
83
+ }
84
+
85
+ .ds-onboarding-step__check {
86
+ position: relative;
87
+ z-index: 1;
88
+ display: block;
89
+ flex: 0 0 auto;
90
+ width: var(--onboarding-step-check-size);
91
+ height: var(--onboarding-step-check-size);
92
+ color: var(--onboarding-step-content-success);
93
+ }
94
+
95
+ .ds-onboarding-step__line {
96
+ position: absolute;
97
+ left: 50%;
98
+ width: var(--onboarding-step-line-width);
99
+ transform: translateX(-50%);
100
+ background: var(--onboarding-step-border-default);
101
+ }
102
+
103
+ .ds-onboarding-step__line--leading {
104
+ top: var(--onboarding-step-line-offset);
105
+ height: var(--onboarding-step-line-segment-height);
106
+ }
107
+
108
+ .ds-onboarding-step__line--trailing {
109
+ bottom: var(--onboarding-step-line-offset);
110
+ height: var(--onboarding-step-line-segment-height);
111
+ }
112
+
113
+ .ds-onboarding-step__line--active {
114
+ position: relative;
115
+ left: auto;
116
+ height: var(--onboarding-step-check-size);
117
+ transform: none;
118
+ background: var(--onboarding-step-border-brand-strong);
119
+ }
120
+
121
+ .ds-onboarding-step__line--inactive {
122
+ position: relative;
123
+ left: auto;
124
+ height: var(--onboarding-step-height);
125
+ transform: none;
126
+ }
@@ -0,0 +1,287 @@
1
+ .ds-page-header {
2
+ --page-header-border-default: var(--bh-border-default);
3
+ --page-header-content-brand: var(--bh-content-brand-default);
4
+ --page-header-content-default: var(--bh-content-default);
5
+ --page-header-content-heading: var(--bh-content-default);
6
+ --page-header-content-muted: var(--bh-content-muted);
7
+ --page-header-content-subtle: var(--bh-content-subtle);
8
+ --page-header-interactive-secondary: var(--bh-interactive-secondary-default);
9
+ --page-header-interactive-secondary-hover: var(--bh-bg-raised);
10
+ --page-header-control-radius: var(--bh-control-default);
11
+ --page-header-space-xs: var(--bh-space-xs-4);
12
+ --page-header-space-md: var(--bh-space-md-8);
13
+ --page-header-space-lg: var(--bh-space-lg-10);
14
+ --page-header-space-xl: var(--bh-space-xl-12);
15
+ --page-header-space-2xl: var(--bh-space-2xl-14);
16
+ --page-header-space-3xl: var(--bh-space-3xl-16);
17
+ --page-header-space-4xl: var(--bh-space-4xl-20);
18
+ --page-header-space-7xl: var(--bh-space-7xl-40);
19
+ --page-header-action-height: calc(var(--bh-space-6xl-32) + var(--bh-space-xs-4));
20
+
21
+ box-sizing: border-box;
22
+ width: 100%;
23
+ display: flex;
24
+ flex-direction: column;
25
+ align-items: flex-start;
26
+ gap: var(--page-header-space-3xl);
27
+ padding-block: var(--page-header-space-4xl);
28
+ color: var(--page-header-content-default);
29
+ font-family: var(--bh-font-family);
30
+ letter-spacing: var(--bh-text-body-md-regular-letter-spacing);
31
+ }
32
+
33
+ .ds-page-header *,
34
+ .ds-page-header *::before,
35
+ .ds-page-header *::after {
36
+ box-sizing: border-box;
37
+ }
38
+
39
+ .ds-page-header h1,
40
+ .ds-page-header p,
41
+ .ds-page-header ol {
42
+ margin: 0;
43
+ }
44
+
45
+ .ds-page-header button,
46
+ .ds-page-header a {
47
+ font: inherit;
48
+ }
49
+
50
+ .ds-page-header a {
51
+ color: inherit;
52
+ text-decoration: none;
53
+ }
54
+
55
+ .ds-page-header__breadcrumbs {
56
+ color: var(--page-header-content-subtle);
57
+ font-size: var(--bh-text-body-md-medium-font-size);
58
+ font-weight: var(--bh-text-body-md-medium-font-weight);
59
+ line-height: var(--bh-text-body-md-medium-line-height);
60
+ }
61
+
62
+ .ds-page-header__breadcrumbs ol {
63
+ display: flex;
64
+ align-items: center;
65
+ gap: var(--page-header-space-xs);
66
+ padding: 0;
67
+ list-style: none;
68
+ }
69
+
70
+ .ds-page-header__breadcrumbs li,
71
+ .ds-page-header__breadcrumbs a,
72
+ .ds-page-header__breadcrumbs span:not(.ds-page-header__breadcrumb-separator) {
73
+ display: inline-flex;
74
+ align-items: center;
75
+ gap: var(--page-header-space-xs);
76
+ min-width: 0;
77
+ }
78
+
79
+ .ds-page-header__breadcrumbs a:hover {
80
+ color: var(--page-header-content-default);
81
+ }
82
+
83
+ .ds-page-header__breadcrumbs .is-current {
84
+ color: var(--page-header-content-default);
85
+ }
86
+
87
+ .ds-page-header__breadcrumb-label {
88
+ max-width: 20ch;
89
+ overflow: hidden;
90
+ text-overflow: ellipsis;
91
+ white-space: nowrap;
92
+ }
93
+
94
+ .ds-page-header__breadcrumb-icon {
95
+ width: var(--page-header-space-4xl);
96
+ height: var(--page-header-space-4xl);
97
+ display: inline-grid;
98
+ place-items: center;
99
+ color: currentColor;
100
+ }
101
+
102
+ .ds-page-header__breadcrumb-separator {
103
+ width: var(--page-header-space-3xl);
104
+ height: var(--page-header-space-3xl);
105
+ display: inline-flex;
106
+ align-items: center;
107
+ justify-content: center;
108
+ color: var(--page-header-content-subtle);
109
+ line-height: var(--bh-text-body-2xs-regular-line-height);
110
+ }
111
+
112
+ .ds-page-header__section {
113
+ width: 100%;
114
+ display: flex;
115
+ flex-direction: column;
116
+ align-items: flex-start;
117
+ gap: var(--page-header-space-xs);
118
+ }
119
+
120
+ .ds-page-header__topline {
121
+ width: 100%;
122
+ display: flex;
123
+ align-items: center;
124
+ gap: var(--page-header-space-7xl);
125
+ }
126
+
127
+ .ds-page-header__copy {
128
+ min-width: 0;
129
+ flex: 1 1 auto;
130
+ display: flex;
131
+ flex-direction: column;
132
+ align-items: flex-start;
133
+ gap: var(--page-header-space-xs);
134
+ }
135
+
136
+ .ds-page-header__heading-row {
137
+ width: 100%;
138
+ min-width: 0;
139
+ display: flex;
140
+ align-items: center;
141
+ gap: var(--page-header-space-lg);
142
+ }
143
+
144
+ .ds-page-header__heading-main {
145
+ min-width: 0;
146
+ display: flex;
147
+ align-items: center;
148
+ gap: var(--page-header-space-md);
149
+ }
150
+
151
+ .ds-page-header__icon {
152
+ width: var(--bh-space-5xl-24);
153
+ height: var(--bh-space-5xl-24);
154
+ flex: 0 0 auto;
155
+ display: inline-grid;
156
+ place-items: center;
157
+ color: var(--page-header-content-subtle);
158
+ }
159
+
160
+ .ds-page-header__home-icon {
161
+ width: var(--bh-space-5xl-24);
162
+ height: var(--bh-space-5xl-24);
163
+ display: block;
164
+ }
165
+
166
+ .ds-page-header h1 {
167
+ min-width: 0;
168
+ color: var(--page-header-content-heading);
169
+ font-size: var(--bh-text-heading-md-semibold-font-size);
170
+ font-weight: var(--bh-text-heading-md-semibold-font-weight);
171
+ line-height: var(--bh-text-heading-md-semibold-line-height);
172
+ overflow-wrap: anywhere;
173
+ }
174
+
175
+ .ds-page-header__meta {
176
+ flex: 0 0 auto;
177
+ padding-top: var(--bh-space-xxs-2);
178
+ color: var(--page-header-content-muted);
179
+ font-size: var(--bh-text-body-2xs-regular-font-size);
180
+ font-weight: var(--bh-text-body-2xs-regular-font-weight);
181
+ line-height: var(--bh-text-body-2xs-regular-line-height);
182
+ white-space: nowrap;
183
+ }
184
+
185
+ .ds-page-header__description {
186
+ width: 100%;
187
+ color: var(--page-header-content-subtle);
188
+ font-size: var(--bh-text-body-md-regular-font-size);
189
+ font-weight: var(--bh-text-body-md-regular-font-weight);
190
+ line-height: var(--bh-text-body-md-regular-line-height);
191
+ }
192
+
193
+ .ds-page-header__actions {
194
+ flex: 0 0 auto;
195
+ display: flex;
196
+ align-items: center;
197
+ gap: var(--page-header-space-md);
198
+ }
199
+
200
+ .ds-page-header__action {
201
+ min-width: 0;
202
+ height: var(--page-header-action-height);
203
+ border: var(--bh-space-xxxs-1) solid var(--page-header-border-default);
204
+ border-radius: var(--page-header-control-radius);
205
+ display: inline-flex;
206
+ align-items: center;
207
+ justify-content: center;
208
+ padding: 0 var(--page-header-space-xl);
209
+ background: var(--page-header-interactive-secondary);
210
+ box-shadow: var(--shadow-button-secondary);
211
+ color: var(--page-header-content-default);
212
+ cursor: pointer;
213
+ font-size: var(--bh-text-body-md-medium-font-size);
214
+ font-weight: var(--bh-text-body-md-medium-font-weight);
215
+ line-height: var(--bh-text-body-md-medium-line-height);
216
+ white-space: nowrap;
217
+ }
218
+
219
+ .ds-page-header__action:hover {
220
+ background: var(--page-header-interactive-secondary-hover);
221
+ }
222
+
223
+ .ds-page-header__action:disabled {
224
+ cursor: not-allowed;
225
+ opacity: var(--bh-opacity-muted);
226
+ }
227
+
228
+ .ds-page-header__action:focus-visible,
229
+ .ds-page-header__breadcrumbs a:focus-visible {
230
+ outline: var(--bh-space-xxs-2) solid var(--page-header-content-brand);
231
+ outline-offset: var(--bh-space-xxs-2);
232
+ }
233
+
234
+ .ds-page-header__tabs {
235
+ width: 100%;
236
+ }
237
+
238
+ .ds-page-header[dir="rtl"] {
239
+ font-family: var(--bh-font-family);
240
+ }
241
+
242
+ .ds-page-header[dir="rtl"] .ds-page-header__topline,
243
+ .ds-page-header[dir="rtl"] .ds-page-header__heading-row,
244
+ .ds-page-header[dir="rtl"] .ds-page-header__heading-main,
245
+ .ds-page-header[dir="rtl"] .ds-page-header__actions,
246
+ .ds-page-header[dir="rtl"] .ds-page-header__breadcrumbs ol {
247
+ direction: rtl;
248
+ }
249
+
250
+ /* Approved exception: media query breakpoints stay literal because CSS vars are not reliable in query conditions. */
251
+ @media (max-width: 820px) {
252
+ .ds-page-header__topline {
253
+ align-items: flex-start;
254
+ flex-direction: column;
255
+ gap: var(--page-header-space-2xl);
256
+ }
257
+
258
+ .ds-page-header__actions {
259
+ width: 100%;
260
+ flex-wrap: wrap;
261
+ }
262
+ }
263
+
264
+ @media (max-width: 560px) {
265
+ .ds-page-header {
266
+ gap: var(--page-header-space-2xl);
267
+ padding-block: var(--page-header-space-3xl);
268
+ }
269
+
270
+ .ds-page-header__breadcrumbs ol {
271
+ flex-wrap: wrap;
272
+ }
273
+
274
+ .ds-page-header__heading-row {
275
+ align-items: flex-start;
276
+ flex-direction: column;
277
+ gap: var(--page-header-space-xs);
278
+ }
279
+
280
+ .ds-page-header__heading-main {
281
+ align-items: flex-start;
282
+ }
283
+
284
+ .ds-page-header__actions {
285
+ gap: var(--page-header-space-xs);
286
+ }
287
+ }