@asafarim/shared-i18n 0.8.1 → 0.9.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 (94) hide show
  1. package/README.md +266 -350
  2. package/demo/README.md +119 -148
  3. package/demo/index.html +12 -1
  4. package/demo/node_modules/.bin/kill-port +17 -0
  5. package/demo/node_modules/.bin/tsc +5 -9
  6. package/demo/node_modules/.bin/tsserver +5 -9
  7. package/demo/node_modules/.bin/vite +5 -9
  8. package/demo/package.json +7 -4
  9. package/demo/public/404.html +24 -0
  10. package/demo/public/favicon.svg +4 -4
  11. package/demo/public/logo.svg +24 -24
  12. package/demo/src/App.tsx +178 -129
  13. package/demo/src/components/CountryLanguageSelectorsPage.tsx +240 -0
  14. package/demo/src/components/GetStartedSection.tsx +56 -56
  15. package/demo/src/components/KeyTable.tsx +29 -29
  16. package/demo/src/components/LanguageBar.tsx +145 -103
  17. package/demo/src/components/LanguageSwitcherDemo.module.css +114 -114
  18. package/demo/src/components/LanguageSwitchersPage.tsx +245 -0
  19. package/demo/src/components/Logo.tsx +6 -6
  20. package/demo/src/components/OverviewSection.tsx +58 -43
  21. package/demo/src/components/Panel.tsx +15 -15
  22. package/demo/src/components/RoutingLabPage.tsx +147 -0
  23. package/demo/src/components/StatusCard.tsx +109 -109
  24. package/demo/src/data/countries.ts +48 -0
  25. package/demo/src/i18n/localeAdapter.ts +91 -0
  26. package/demo/src/i18n/localeRouting.ts +77 -0
  27. package/demo/src/index.css +1075 -644
  28. package/demo/src/locales/de/demo.json +202 -84
  29. package/demo/src/locales/en/demo.json +201 -85
  30. package/demo/src/locales/fr/demo.json +203 -85
  31. package/demo/src/locales/it/demo.json +202 -84
  32. package/demo/src/locales/lb/demo.json +201 -0
  33. package/demo/src/locales/nl/demo.json +203 -85
  34. package/demo/src/main.tsx +32 -29
  35. package/demo/tsconfig.json +18 -18
  36. package/demo/tsconfig.node.json +10 -10
  37. package/demo/tsconfig.tsbuildinfo +1 -1
  38. package/demo/vite-env.d.ts +7 -7
  39. package/demo/vite.config.d.ts +2 -2
  40. package/demo/vite.config.js +10 -10
  41. package/dist/components/LanguageSwitcher.module.css +303 -303
  42. package/dist/country-language-selector.css +431 -0
  43. package/dist/index.d.ts +2 -0
  44. package/dist/index.d.ts.map +1 -1
  45. package/dist/index.js +2 -0
  46. package/dist/tsconfig.tsbuildinfo +1 -1
  47. package/package.json +8 -5
  48. package/demo/dist/Icon Dropdown_Limited Languages.png +0 -0
  49. package/demo/dist/Select Dropdown_Text Only.png +0 -0
  50. package/demo/dist/assets/favicon-BZYZvBLo.svg +0 -4
  51. package/demo/dist/assets/index-BdjqKw_N.css +0 -1
  52. package/demo/dist/assets/index-C1Tq1uEr.js +0 -191
  53. package/demo/dist/favicon.svg +0 -4
  54. package/demo/dist/index.html +0 -27
  55. package/demo/dist/logo.svg +0 -24
  56. package/demo/node_modules/.bin/browserslist +0 -21
  57. package/demo/node_modules/.bin/browserslist.CMD +0 -12
  58. package/demo/node_modules/.bin/browserslist.ps1 +0 -41
  59. package/demo/node_modules/.bin/tsc.CMD +0 -12
  60. package/demo/node_modules/.bin/tsc.ps1 +0 -41
  61. package/demo/node_modules/.bin/tsserver.CMD +0 -12
  62. package/demo/node_modules/.bin/tsserver.ps1 +0 -41
  63. package/demo/node_modules/.bin/vite.CMD +0 -12
  64. package/demo/node_modules/.bin/vite.ps1 +0 -41
  65. package/demo/node_modules/.vite/deps/@asafarim_country-language-selector.js +0 -848
  66. package/demo/node_modules/.vite/deps/@asafarim_country-language-selector.js.map +0 -7
  67. package/demo/node_modules/.vite/deps/_metadata.json +0 -76
  68. package/demo/node_modules/.vite/deps/chunk-5WRI5ZAA.js +0 -30
  69. package/demo/node_modules/.vite/deps/chunk-5WRI5ZAA.js.map +0 -7
  70. package/demo/node_modules/.vite/deps/chunk-B3AHR5EX.js +0 -1004
  71. package/demo/node_modules/.vite/deps/chunk-B3AHR5EX.js.map +0 -7
  72. package/demo/node_modules/.vite/deps/chunk-E6BG6WAU.js +0 -292
  73. package/demo/node_modules/.vite/deps/chunk-E6BG6WAU.js.map +0 -7
  74. package/demo/node_modules/.vite/deps/chunk-MVARZQEG.js +0 -280
  75. package/demo/node_modules/.vite/deps/chunk-MVARZQEG.js.map +0 -7
  76. package/demo/node_modules/.vite/deps/i18next-browser-languagedetector.js +0 -400
  77. package/demo/node_modules/.vite/deps/i18next-browser-languagedetector.js.map +0 -7
  78. package/demo/node_modules/.vite/deps/i18next.js +0 -2392
  79. package/demo/node_modules/.vite/deps/i18next.js.map +0 -7
  80. package/demo/node_modules/.vite/deps/package.json +0 -3
  81. package/demo/node_modules/.vite/deps/react-dom.js +0 -6
  82. package/demo/node_modules/.vite/deps/react-dom.js.map +0 -7
  83. package/demo/node_modules/.vite/deps/react-dom_client.js +0 -20217
  84. package/demo/node_modules/.vite/deps/react-dom_client.js.map +0 -7
  85. package/demo/node_modules/.vite/deps/react-i18next.js +0 -869
  86. package/demo/node_modules/.vite/deps/react-i18next.js.map +0 -7
  87. package/demo/node_modules/.vite/deps/react.js +0 -5
  88. package/demo/node_modules/.vite/deps/react.js.map +0 -7
  89. package/demo/node_modules/.vite/deps/react_jsx-dev-runtime.js +0 -278
  90. package/demo/node_modules/.vite/deps/react_jsx-dev-runtime.js.map +0 -7
  91. package/demo/node_modules/.vite/deps/react_jsx-runtime.js +0 -6
  92. package/demo/node_modules/.vite/deps/react_jsx-runtime.js.map +0 -7
  93. package/demo/src/components/CountryLanguageDemo.tsx +0 -140
  94. package/demo/src/components/LanguageSwitcherDemo.tsx +0 -256
@@ -1,644 +1,1075 @@
1
- @import "@asafarim/design-tokens/css";
2
-
3
- * {
4
- margin: 0;
5
- padding: 0;
6
- box-sizing: border-box;
7
- }
8
-
9
- body {
10
- font-family: var(--asm-font-family-base, 'Inter', sans-serif);
11
- -webkit-font-smoothing: antialiased;
12
- -moz-osx-font-smoothing: grayscale;
13
- background-color: var(--asm-color-bg);
14
- color: var(--asm-color-text);
15
- }
16
-
17
- .app-container {
18
- min-height: 100vh;
19
- display: flex;
20
- flex-direction: column;
21
- }
22
-
23
- .app-header {
24
- background-color: var(--asm-color-primary-600);
25
- color: var(--asm-color-bg);
26
- padding: var(--asm-space-10);
27
- box-shadow: var(--asm-effect-shadow-md);
28
- display: flex;
29
- justify-content: space-between;
30
- align-items: flex-start;
31
- gap: var(--asm-space-6);
32
- flex-wrap: wrap;
33
- }
34
-
35
- .header-content {
36
- flex: 1;
37
- min-width: 300px;
38
- }
39
-
40
- .app-header h1 {
41
- font-size: 2rem;
42
- margin-bottom: var(--asm-space-2);
43
- }
44
-
45
- .subtitle {
46
- font-size: 0.95rem;
47
- opacity: 0.9;
48
- }
49
-
50
- .app-main {
51
- flex: 1;
52
- max-width: 1200px;
53
- width: 100%;
54
- margin: 0 auto;
55
- padding: var(--asm-space-10);
56
- gap: var(--asm-space-10);
57
- display: flex;
58
- flex-direction: column;
59
- }
60
-
61
- .panel {
62
- background-color: var(--asm-color-surface);
63
- border: 1px solid var(--asm-color-border);
64
- border-radius: var(--asm-radius-lg);
65
- padding: var(--asm-space-6);
66
- box-shadow: var(--asm-effect-shadow-sm);
67
- }
68
-
69
- .panel-title {
70
- font-size: 1.25rem;
71
- font-weight: 600;
72
- margin-bottom: var(--asm-space-4);
73
- color: var(--asm-color-text);
74
- }
75
-
76
- .panel-grid {
77
- display: grid;
78
- grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
79
- gap: var(--asm-space-6);
80
- }
81
-
82
- .panel-grid h3 {
83
- font-size: 1rem;
84
- margin-bottom: var(--asm-space-3);
85
- color: var(--asm-color-text-muted);
86
- }
87
-
88
- .key-table {
89
- width: 100%;
90
- border-collapse: collapse;
91
- font-size: 0.9rem;
92
- }
93
-
94
- .key-table th,
95
- .key-table td {
96
- padding: var(--asm-space-4);
97
- text-align: left;
98
- border-bottom: 1px solid var(--asm-color-border);
99
- }
100
-
101
- .key-table th {
102
- background-color: var(--asm-color-surface-muted);
103
- font-weight: 600;
104
- color: var(--asm-color-text-muted);
105
- }
106
-
107
- .key-table tr:hover {
108
- background-color: var(--asm-color-surface-muted);
109
- }
110
-
111
- .language-bar {
112
- display: flex;
113
- gap: var(--asm-space-3);
114
- }
115
-
116
- .package-source-actions {
117
- display: flex;
118
- align-items: center;
119
- gap: var(--asm-space-2);
120
- }
121
-
122
- .icon-button {
123
- display: inline-flex;
124
- align-items: center;
125
- justify-content: center;
126
- width: 2.5rem;
127
- height: 2.5rem;
128
- padding: 0;
129
- border: 1px solid var(--asm-color-border);
130
- background: var(--asm-color-surface);
131
- border-radius: var(--asm-radius-md);
132
- color: var(--asm-color-text);
133
- cursor: pointer;
134
- font-size: 1rem;
135
- transition: all var(--asm-motion-duration-fast) var(--asm-motion-easing-standard);
136
- text-decoration: none;
137
- }
138
-
139
- .icon-button:hover:not(:disabled) {
140
- background: var(--asm-color-surface-muted);
141
- border-color: var(--asm-color-primary-600);
142
- box-shadow: var(--asm-effect-shadow-sm);
143
- }
144
-
145
- .icon-button:disabled {
146
- opacity: 0.5;
147
- cursor: not-allowed;
148
- }
149
-
150
- .icon-button:focus {
151
- outline: 2px solid var(--asm-color-primary-600);
152
- outline-offset: 2px;
153
- }
154
-
155
- .lang-button {
156
- padding: var(--asm-space-2) var(--asm-space-4);
157
- border: 2px solid var(--asm-color-bg);
158
- background-color: transparent;
159
- color: var(--asm-color-bg);
160
- border-radius: var(--asm-radius-md);
161
- cursor: pointer;
162
- font-size: 0.95rem;
163
- font-weight: 500;
164
- transition: all 0.2s ease;
165
- }
166
-
167
- .lang-button:hover:not(:disabled) {
168
- background-color: var(--asm-color-button-ghost-bg-hover);
169
- }
170
-
171
- .lang-button.active {
172
- background-color: var(--asm-color-bg);
173
- color: var(--asm-color-primary-600);
174
- }
175
-
176
- .lang-button:disabled {
177
- opacity: 0.6;
178
- cursor: not-allowed;
179
- }
180
-
181
- .interpolation-demo {
182
- display: flex;
183
- flex-direction: column;
184
- gap: var(--asm-space-6);
185
- }
186
-
187
- .demo-item {
188
- padding: var(--asm-space-6);
189
- background-color: var(--asm-color-surface-muted);
190
- border-radius: var(--asm-radius-md);
191
- border-left: 4px solid var(--asm-color-primary-600);
192
- }
193
-
194
- .demo-item h4 {
195
- font-size: 0.95rem;
196
- margin-bottom: var(--asm-space-3);
197
- color: var(--asm-color-text-muted);
198
- }
199
-
200
- .demo-output {
201
- font-size: 1rem;
202
- color: var(--asm-color-text);
203
- font-weight: 500;
204
- }
205
-
206
- .status-grid {
207
- display: grid;
208
- grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
209
- gap: var(--asm-space-6);
210
- }
211
-
212
- .status-card {
213
- background-color: var(--asm-color-surface-muted);
214
- border: 1px solid var(--asm-color-border);
215
- border-radius: var(--asm-radius-md);
216
- padding: var(--asm-space-6);
217
- }
218
-
219
- .status-card h4 {
220
- font-size: 0.9rem;
221
- color: var(--asm-color-text-muted);
222
- margin-bottom: var(--asm-space-2);
223
- text-transform: uppercase;
224
- letter-spacing: 0.05em;
225
- }
226
-
227
- .status-card p {
228
- font-size: 1rem;
229
- color: var(--asm-color-text);
230
- word-break: break-all;
231
- }
232
-
233
- .status-list {
234
- list-style: none;
235
- margin-top: var(--asm-space-3);
236
- }
237
-
238
- .status-list li {
239
- padding: var(--asm-space-2) 0;
240
- color: var(--asm-color-text);
241
- font-size: 0.95rem;
242
- }
243
-
244
- .sync-button {
245
- margin-top: var(--asm-space-4);
246
- padding: var(--asm-space-3) var(--asm-space-6);
247
- background-color: var(--asm-color-button-primary-bg);
248
- color: var(--asm-color-button-primary-text);
249
- border: none;
250
- border-radius: var(--asm-radius-md);
251
- cursor: pointer;
252
- font-size: 0.95rem;
253
- font-weight: 500;
254
- transition: all 0.2s ease;
255
- }
256
-
257
- .sync-button:hover:not(:disabled) {
258
- background-color: var(--asm-color-button-primary-bg-hover);
259
- box-shadow: var(--asm-effect-shadow-sm);
260
- }
261
-
262
- .sync-button:disabled {
263
- opacity: 0.6;
264
- cursor: not-allowed;
265
- }
266
-
267
- .sync-result {
268
- margin-top: var(--asm-space-3);
269
- padding: var(--asm-space-4);
270
- border-radius: var(--asm-radius-md);
271
- font-size: 0.9rem;
272
- }
273
-
274
- .sync-result.success {
275
- background-color: var(--asm-color-success-100);
276
- color: var(--asm-color-success-600);
277
- border: 1px solid var(--asm-color-success-200);
278
- }
279
-
280
- .sync-result.error {
281
- background-color: var(--asm-color-danger-100);
282
- color: var(--asm-color-danger-600);
283
- border: 1px solid var(--asm-color-danger-200);
284
- }
285
-
286
- .nav-tabs {
287
- display: flex;
288
- gap: var(--asm-space-2);
289
- margin-bottom: var(--asm-space-6);
290
- border-bottom: 2px solid var(--asm-color-border);
291
- overflow-x: auto;
292
- }
293
-
294
- .nav-tab {
295
- padding: var(--asm-space-3) var(--asm-space-4);
296
- background: none;
297
- border: none;
298
- border-bottom: 3px solid transparent;
299
- color: var(--asm-color-text-muted);
300
- cursor: pointer;
301
- font-size: 0.95rem;
302
- font-weight: 500;
303
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
304
- white-space: nowrap;
305
- }
306
-
307
- .nav-tab:hover {
308
- color: var(--asm-color-text);
309
- }
310
-
311
- .nav-tab.active {
312
- color: var(--asm-color-primary-600);
313
- border-bottom-color: var(--asm-color-primary-600);
314
- }
315
-
316
- .overview-section {
317
- animation: fadeIn var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
318
- }
319
-
320
- .overview-header {
321
- margin-bottom: var(--asm-space-8);
322
- }
323
-
324
- .overview-title {
325
- font-size: 2rem;
326
- font-weight: 700;
327
- color: var(--asm-color-text);
328
- margin-bottom: var(--asm-space-3);
329
- }
330
-
331
- .overview-description {
332
- font-size: 1.125rem;
333
- color: var(--asm-color-text-muted);
334
- line-height: 1.6;
335
- }
336
-
337
- .overview-grid {
338
- display: grid;
339
- grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
340
- gap: var(--asm-space-6);
341
- }
342
-
343
- .feature-card {
344
- background: linear-gradient(135deg, var(--asm-color-surface) 0%, var(--asm-color-surface-muted) 100%);
345
- border: 1px solid var(--asm-color-border);
346
- border-radius: var(--asm-radius-lg);
347
- padding: var(--asm-space-6);
348
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
349
- }
350
-
351
- .feature-card:hover {
352
- transform: translateY(-4px);
353
- box-shadow: var(--asm-effect-shadow-lg);
354
- border-color: var(--asm-color-primary-600);
355
- }
356
-
357
- .feature-icon {
358
- font-size: 2.5rem;
359
- margin-bottom: var(--asm-space-3);
360
- display: inline-block;
361
- }
362
-
363
- .feature-card h3 {
364
- font-size: 1.25rem;
365
- font-weight: 600;
366
- color: var(--asm-color-text);
367
- margin-bottom: var(--asm-space-4);
368
- }
369
-
370
- .feature-list {
371
- list-style: none;
372
- display: flex;
373
- flex-direction: column;
374
- gap: var(--asm-space-3);
375
- }
376
-
377
- .feature-list li {
378
- display: flex;
379
- align-items: flex-start;
380
- gap: var(--asm-space-2);
381
- color: var(--asm-color-text);
382
- line-height: 1.5;
383
- }
384
-
385
- .feature-dot {
386
- color: var(--asm-color-primary-600);
387
- font-weight: bold;
388
- flex-shrink: 0;
389
- }
390
-
391
- .get-started-section {
392
- animation: fadeIn var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
393
- }
394
-
395
- .gs-header {
396
- margin-bottom: var(--asm-space-8);
397
- }
398
-
399
- .gs-title {
400
- font-size: 2rem;
401
- font-weight: 700;
402
- color: var(--asm-color-text);
403
- margin-bottom: var(--asm-space-3);
404
- }
405
-
406
- .gs-intro {
407
- font-size: 1.125rem;
408
- color: var(--asm-color-text-muted);
409
- line-height: 1.6;
410
- }
411
-
412
- .steps-container {
413
- display: flex;
414
- flex-direction: column;
415
- gap: var(--asm-space-4);
416
- margin-bottom: var(--asm-space-8);
417
- }
418
-
419
- .step-item {
420
- border: 1px solid var(--asm-color-border);
421
- border-radius: var(--asm-radius-lg);
422
- overflow: hidden;
423
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
424
- }
425
-
426
- .step-item:hover {
427
- border-color: var(--asm-color-primary-600);
428
- box-shadow: var(--asm-effect-shadow-md);
429
- }
430
-
431
- .step-header {
432
- width: 100%;
433
- display: flex;
434
- align-items: center;
435
- gap: var(--asm-space-4);
436
- padding: var(--asm-space-4) var(--asm-space-6);
437
- background-color: var(--asm-color-surface);
438
- border: none;
439
- cursor: pointer;
440
- transition: all var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
441
- }
442
-
443
- .step-header:hover {
444
- background-color: var(--asm-color-surface-muted);
445
- }
446
-
447
- .step-header.expanded {
448
- background-color: var(--asm-color-surface-muted);
449
- }
450
-
451
- .step-number {
452
- display: flex;
453
- align-items: center;
454
- justify-content: center;
455
- width: 40px;
456
- height: 40px;
457
- border-radius: var(--asm-radius-full);
458
- background: linear-gradient(135deg, var(--asm-color-primary-600) 0%, var(--asm-color-primary-700) 100%);
459
- color: white;
460
- font-weight: 700;
461
- font-size: 1.125rem;
462
- flex-shrink: 0;
463
- }
464
-
465
- .step-info {
466
- flex: 1;
467
- text-align: left;
468
- }
469
-
470
- .step-info h3 {
471
- font-size: 1rem;
472
- font-weight: 600;
473
- color: var(--asm-color-text);
474
- margin-bottom: var(--asm-space-1);
475
- }
476
-
477
- .step-info p {
478
- font-size: 0.9rem;
479
- color: var(--asm-color-text-muted);
480
- }
481
-
482
- .step-toggle {
483
- font-size: 1.5rem;
484
- color: var(--asm-color-primary-600);
485
- font-weight: bold;
486
- flex-shrink: 0;
487
- }
488
-
489
- .step-content {
490
- padding: var(--asm-space-6);
491
- background-color: var(--asm-color-surface-muted);
492
- border-top: 1px solid var(--asm-color-border);
493
- animation: slideDown var(--asm-motion-duration-normal) var(--asm-motion-easing-standard);
494
- }
495
-
496
- .code-block {
497
- background-color: var(--asm-color-text);
498
- color: var(--asm-color-bg);
499
- padding: var(--asm-space-4);
500
- border-radius: var(--asm-radius-md);
501
- overflow-x: auto;
502
- font-family: var(--asm-font-family-mono, monospace);
503
- font-size: 0.85rem;
504
- line-height: 1.5;
505
- margin: 0;
506
- }
507
-
508
- .tips-section {
509
- display: flex;
510
- gap: var(--asm-space-6);
511
- padding: var(--asm-space-6);
512
- background: linear-gradient(135deg, var(--asm-color-primary-50) 0%, var(--asm-color-secondary-50) 100%);
513
- border: 2px solid var(--asm-color-primary-200);
514
- border-radius: var(--asm-radius-lg);
515
- }
516
-
517
- .tips-icon {
518
- font-size: 2rem;
519
- flex-shrink: 0;
520
- }
521
-
522
- .tips-content h3 {
523
- font-size: 1.125rem;
524
- font-weight: 600;
525
- color: var(--asm-color-text);
526
- margin-bottom: var(--asm-space-3);
527
- }
528
-
529
- .tips-list {
530
- list-style: none;
531
- display: flex;
532
- flex-direction: column;
533
- gap: var(--asm-space-2);
534
- }
535
-
536
- .tips-list li {
537
- display: flex;
538
- align-items: flex-start;
539
- gap: var(--asm-space-2);
540
- color: var(--asm-color-text);
541
- font-size: 0.95rem;
542
- line-height: 1.5;
543
- }
544
-
545
- .tips-list li::before {
546
- content: "✓";
547
- color: var(--asm-color-semantic-success);
548
- font-weight: bold;
549
- flex-shrink: 0;
550
- }
551
-
552
- @media (max-width: 768px) {
553
- .app-header {
554
- flex-direction: column;
555
- }
556
-
557
- .app-main {
558
- padding: var(--asm-space-6);
559
- }
560
-
561
- .panel-grid {
562
- grid-template-columns: 1fr;
563
- }
564
-
565
- .app-header h1 {
566
- font-size: 1.5rem;
567
- }
568
-
569
- .overview-grid {
570
- grid-template-columns: 1fr;
571
- }
572
-
573
- .tips-section {
574
- flex-direction: column;
575
- }
576
-
577
- .step-header {
578
- flex-direction: column;
579
- align-items: flex-start;
580
- }
581
-
582
- .step-toggle {
583
- align-self: flex-end;
584
- margin-top: calc(var(--asm-space-4) * -1);
585
- }
586
- }
587
-
588
- @keyframes fadeIn {
589
- from {
590
- opacity: 0;
591
- transform: translateY(8px);
592
- }
593
- to {
594
- opacity: 1;
595
- transform: translateY(0);
596
- }
597
- }
598
-
599
- @keyframes slideDown {
600
- from {
601
- opacity: 0;
602
- max-height: 0;
603
- }
604
- to {
605
- opacity: 1;
606
- max-height: 500px;
607
- }
608
- }
609
-
610
- .logo {
611
- width: 70px;
612
- height: 70px;
613
- }
614
-
615
- .logo img {
616
- width: 100%;
617
- height: 100%;
618
- }
619
-
620
-
621
-
622
- /* Mobile adjustments */
623
- @media (max-width: 768px) {
624
- .logo {
625
- width: 50px;
626
- height: 50px;
627
- }
628
- }
629
-
630
- /* Tablet adjustments */
631
- @media (min-width: 769px) and (max-width: 1024px) {
632
- .logo {
633
- width: 60px;
634
- height: 60px;
635
- }
636
- }
637
-
638
- /* Desktop adjustments */
639
- @media (min-width: 1025px) {
640
- .logo {
641
- width: 70px;
642
- height: 70px;
643
- }
644
- }
1
+ @import "@asafarim/design-tokens/css";
2
+
3
+ :root {
4
+ --demo-bg: #f6f7f9;
5
+ --demo-bg-elev: #ffffff;
6
+ --demo-surface: #ffffff;
7
+ --demo-surface-muted: #f1f2f5;
8
+ --demo-border: #e3e5ea;
9
+ --demo-border-strong: #cfd2d8;
10
+ --demo-text: #1a1d23;
11
+ --demo-text-muted: #5b616b;
12
+ --demo-text-subtle: #828893;
13
+ --demo-accent: #2f6feb;
14
+ --demo-accent-hover: #1f56c8;
15
+ --demo-accent-soft: rgba(47, 111, 235, 0.1);
16
+ --demo-success: #168f53;
17
+ --demo-warning: #b3700a;
18
+ --demo-radius: 8px;
19
+ --demo-radius-sm: 6px;
20
+ --demo-shadow-sm: 0 1px 2px rgba(15, 18, 25, 0.06);
21
+ --demo-shadow-md: 0 4px 12px rgba(15, 18, 25, 0.08);
22
+ --demo-shadow-nav: 0 1px 0 rgba(15, 18, 25, 0.06);
23
+ --demo-glass: rgba(255, 255, 255, 0.78);
24
+ --demo-mono: ui-monospace, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
25
+ }
26
+
27
+ [data-theme="dark"] {
28
+ --demo-bg: #0f1115;
29
+ --demo-bg-elev: #14171c;
30
+ --demo-surface: #181c22;
31
+ --demo-surface-muted: #1f242c;
32
+ --demo-border: #2a2f38;
33
+ --demo-border-strong: #3a414c;
34
+ --demo-text: #f1f2f5;
35
+ --demo-text-muted: #b0b5bf;
36
+ --demo-text-subtle: #818794;
37
+ --demo-accent: #6f9bff;
38
+ --demo-accent-hover: #8db1ff;
39
+ --demo-accent-soft: rgba(111, 155, 255, 0.16);
40
+ --demo-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
41
+ --demo-shadow-md: 0 6px 18px rgba(0, 0, 0, 0.45);
42
+ --demo-shadow-nav: 0 1px 0 rgba(255, 255, 255, 0.04);
43
+ --demo-glass: rgba(20, 23, 28, 0.78);
44
+ }
45
+
46
+ * {
47
+ box-sizing: border-box;
48
+ }
49
+
50
+ html, body, #root {
51
+ margin: 0;
52
+ padding: 0;
53
+ }
54
+
55
+ body {
56
+ font-family: var(--asm-font-family-base, 'Inter', system-ui, sans-serif);
57
+ -webkit-font-smoothing: antialiased;
58
+ -moz-osx-font-smoothing: grayscale;
59
+ background: var(--demo-bg);
60
+ color: var(--demo-text);
61
+ font-size: 15px;
62
+ line-height: 1.5;
63
+ }
64
+
65
+ a {
66
+ color: var(--demo-accent);
67
+ text-decoration: none;
68
+ }
69
+ a:hover { text-decoration: underline; }
70
+
71
+ code, pre {
72
+ font-family: var(--demo-mono);
73
+ font-size: 0.9em;
74
+ }
75
+
76
+ h1, h2, h3, h4 {
77
+ margin: 0;
78
+ color: var(--demo-text);
79
+ font-weight: 650;
80
+ letter-spacing: -0.01em;
81
+ }
82
+
83
+ p { margin: 0; }
84
+
85
+ button {
86
+ font: inherit;
87
+ color: inherit;
88
+ }
89
+
90
+ /* ---------- App shell ---------- */
91
+
92
+ .app-shell {
93
+ min-height: 100vh;
94
+ display: flex;
95
+ flex-direction: column;
96
+ }
97
+
98
+ .app-main {
99
+ flex: 1;
100
+ width: 100%;
101
+ max-width: 1200px;
102
+ margin: 0 auto;
103
+ padding: 32px 24px 64px;
104
+ display: flex;
105
+ flex-direction: column;
106
+ gap: 48px;
107
+ }
108
+
109
+ .app-footer {
110
+ border-top: 1px solid var(--demo-border);
111
+ padding: 16px 24px;
112
+ display: flex;
113
+ justify-content: space-between;
114
+ gap: 16px;
115
+ flex-wrap: wrap;
116
+ font-size: 0.85rem;
117
+ color: var(--demo-text-muted);
118
+ background: var(--demo-bg-elev);
119
+ }
120
+ .app-footer code {
121
+ background: var(--demo-surface-muted);
122
+ padding: 2px 6px;
123
+ border-radius: 4px;
124
+ color: var(--demo-text);
125
+ }
126
+
127
+ /* ---------- Top navigation ---------- */
128
+
129
+ .topnav {
130
+ position: sticky;
131
+ top: 0;
132
+ z-index: 50;
133
+ background: var(--demo-glass);
134
+ backdrop-filter: saturate(180%) blur(12px);
135
+ -webkit-backdrop-filter: saturate(180%) blur(12px);
136
+ border-bottom: 1px solid var(--demo-border);
137
+ box-shadow: var(--demo-shadow-nav);
138
+ }
139
+
140
+ .topnav__inner {
141
+ max-width: 1280px;
142
+ margin: 0 auto;
143
+ padding: 10px 20px;
144
+ display: grid;
145
+ grid-template-columns: auto 1fr auto;
146
+ align-items: center;
147
+ gap: 20px;
148
+ }
149
+
150
+ .topnav__brand {
151
+ display: flex;
152
+ align-items: center;
153
+ gap: 12px;
154
+ text-decoration: none;
155
+ color: var(--demo-text);
156
+ }
157
+ .topnav__brand:hover { text-decoration: none; }
158
+
159
+ .topnav__brand .logo,
160
+ .topnav__brand .logo img {
161
+ width: 32px;
162
+ height: 32px;
163
+ }
164
+
165
+ .topnav__brand-text {
166
+ display: flex;
167
+ flex-direction: column;
168
+ line-height: 1.15;
169
+ }
170
+ .topnav__brand-name {
171
+ font-weight: 600;
172
+ font-size: 0.95rem;
173
+ font-family: var(--demo-mono);
174
+ }
175
+ .topnav__brand-tag {
176
+ font-size: 0.75rem;
177
+ color: var(--demo-text-subtle);
178
+ }
179
+
180
+ .topnav__pills {
181
+ display: flex;
182
+ gap: 4px;
183
+ justify-content: center;
184
+ flex-wrap: wrap;
185
+ background: var(--demo-surface-muted);
186
+ border: 1px solid var(--demo-border);
187
+ border-radius: var(--demo-radius);
188
+ padding: 4px;
189
+ }
190
+
191
+ .pill {
192
+ padding: 6px 12px;
193
+ border: none;
194
+ background: transparent;
195
+ border-radius: var(--demo-radius-sm);
196
+ font-size: 0.85rem;
197
+ font-weight: 500;
198
+ color: var(--demo-text-muted);
199
+ cursor: pointer;
200
+ transition: background 0.15s ease, color 0.15s ease;
201
+ white-space: nowrap;
202
+ }
203
+ .pill:hover { color: var(--demo-text); }
204
+ .pill--active {
205
+ background: var(--demo-bg-elev);
206
+ color: var(--demo-text);
207
+ box-shadow: var(--demo-shadow-sm);
208
+ }
209
+
210
+ .topnav__actions {
211
+ display: flex;
212
+ align-items: center;
213
+ gap: 8px;
214
+ flex-wrap: wrap;
215
+ justify-content: flex-end;
216
+ }
217
+
218
+ .locale-chip {
219
+ display: inline-flex;
220
+ align-items: center;
221
+ gap: 6px;
222
+ padding: 4px 10px;
223
+ font-size: 0.75rem;
224
+ font-weight: 600;
225
+ letter-spacing: 0.02em;
226
+ border-radius: 999px;
227
+ background: var(--demo-accent-soft);
228
+ color: var(--demo-accent);
229
+ border: 1px solid transparent;
230
+ }
231
+ .locale-chip__dot {
232
+ width: 6px;
233
+ height: 6px;
234
+ border-radius: 50%;
235
+ background: currentColor;
236
+ }
237
+ .locale-chip__slug {
238
+ margin-left: 4px;
239
+ padding: 1px 6px;
240
+ font-family: var(--demo-mono);
241
+ background: var(--demo-bg-elev);
242
+ color: var(--demo-text-muted);
243
+ border-radius: 4px;
244
+ font-weight: 500;
245
+ }
246
+
247
+ .icon-button {
248
+ width: 34px;
249
+ height: 34px;
250
+ display: inline-flex;
251
+ align-items: center;
252
+ justify-content: center;
253
+ border-radius: var(--demo-radius-sm);
254
+ border: 1px solid var(--demo-border);
255
+ background: var(--demo-surface);
256
+ color: var(--demo-text);
257
+ cursor: pointer;
258
+ transition: background 0.15s ease, border-color 0.15s ease;
259
+ text-decoration: none;
260
+ font-size: 0.95rem;
261
+ padding: 0;
262
+ }
263
+ .icon-button:hover {
264
+ background: var(--demo-surface-muted);
265
+ border-color: var(--demo-border-strong);
266
+ text-decoration: none;
267
+ }
268
+ .icon-button:focus-visible {
269
+ outline: 2px solid var(--demo-accent);
270
+ outline-offset: 2px;
271
+ }
272
+
273
+ /* ---------- Hero ---------- */
274
+
275
+ .hero {
276
+ display: grid;
277
+ grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
278
+ gap: 32px;
279
+ align-items: stretch;
280
+ }
281
+
282
+ .hero__content {
283
+ display: flex;
284
+ flex-direction: column;
285
+ gap: 16px;
286
+ justify-content: center;
287
+ }
288
+
289
+ .hero__eyebrow {
290
+ font-size: 0.75rem;
291
+ font-weight: 600;
292
+ letter-spacing: 0.06em;
293
+ text-transform: uppercase;
294
+ color: var(--demo-text-subtle);
295
+ font-family: var(--demo-mono);
296
+ }
297
+
298
+ .hero__title {
299
+ font-size: clamp(2rem, 4vw, 2.75rem);
300
+ line-height: 1.1;
301
+ letter-spacing: -0.02em;
302
+ }
303
+
304
+ .hero__subtitle {
305
+ font-size: 1.05rem;
306
+ color: var(--demo-text-muted);
307
+ max-width: 56ch;
308
+ }
309
+
310
+ .hero__cta {
311
+ display: flex;
312
+ gap: 12px;
313
+ flex-wrap: wrap;
314
+ margin-top: 8px;
315
+ }
316
+
317
+ .btn {
318
+ padding: 10px 18px;
319
+ border-radius: var(--demo-radius);
320
+ border: 1px solid transparent;
321
+ font-size: 0.9rem;
322
+ font-weight: 600;
323
+ cursor: pointer;
324
+ transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
325
+ }
326
+ .btn--primary {
327
+ background: var(--demo-accent);
328
+ color: #fff;
329
+ border-color: var(--demo-accent);
330
+ }
331
+ .btn--primary:hover { background: var(--demo-accent-hover); border-color: var(--demo-accent-hover); }
332
+ .btn--ghost {
333
+ background: transparent;
334
+ color: var(--demo-text);
335
+ border-color: var(--demo-border-strong);
336
+ }
337
+ .btn--ghost:hover { background: var(--demo-surface-muted); }
338
+
339
+ .url-card {
340
+ background: var(--demo-surface);
341
+ border: 1px solid var(--demo-border);
342
+ border-radius: var(--demo-radius);
343
+ padding: 20px;
344
+ display: flex;
345
+ flex-direction: column;
346
+ gap: 16px;
347
+ }
348
+ .url-card__label {
349
+ font-size: 0.7rem;
350
+ font-weight: 600;
351
+ letter-spacing: 0.08em;
352
+ text-transform: uppercase;
353
+ color: var(--demo-text-subtle);
354
+ }
355
+ .url-card__url {
356
+ font-family: var(--demo-mono);
357
+ font-size: 0.85rem;
358
+ word-break: break-all;
359
+ background: var(--demo-surface-muted);
360
+ border: 1px solid var(--demo-border);
361
+ border-radius: var(--demo-radius-sm);
362
+ padding: 10px 12px;
363
+ color: var(--demo-text-muted);
364
+ }
365
+ .url-card__path { color: var(--demo-accent); font-weight: 600; }
366
+
367
+ .url-card__grid {
368
+ display: grid;
369
+ grid-template-columns: repeat(3, minmax(0, 1fr));
370
+ gap: 12px;
371
+ margin: 0;
372
+ }
373
+ .url-card__grid > div { min-width: 0; }
374
+ .url-card__grid dt {
375
+ font-size: 0.7rem;
376
+ text-transform: uppercase;
377
+ letter-spacing: 0.06em;
378
+ color: var(--demo-text-subtle);
379
+ margin-bottom: 4px;
380
+ }
381
+ .url-card__grid dd {
382
+ margin: 0;
383
+ font-family: var(--demo-mono);
384
+ font-size: 0.85rem;
385
+ color: var(--demo-text);
386
+ word-break: break-all;
387
+ }
388
+
389
+ /* ---------- Sections ---------- */
390
+
391
+ .section-head {
392
+ display: flex;
393
+ flex-direction: column;
394
+ gap: 6px;
395
+ margin-bottom: 16px;
396
+ }
397
+ .section-head h2 {
398
+ font-size: 1.4rem;
399
+ letter-spacing: -0.01em;
400
+ }
401
+ .section-head p {
402
+ color: var(--demo-text-muted);
403
+ font-size: 0.95rem;
404
+ }
405
+
406
+ .surface {
407
+ background: var(--demo-surface);
408
+ border: 1px solid var(--demo-border);
409
+ border-radius: var(--demo-radius);
410
+ padding: 20px;
411
+ }
412
+
413
+ .page-section {
414
+ display: flex;
415
+ flex-direction: column;
416
+ gap: 24px;
417
+ }
418
+ .page-section--stack > * + * { margin-top: 0; }
419
+
420
+ /* ---------- Overview cards ---------- */
421
+
422
+ .overview-section {
423
+ display: flex;
424
+ flex-direction: column;
425
+ gap: 16px;
426
+ }
427
+ .overview-header {
428
+ display: flex;
429
+ flex-direction: column;
430
+ gap: 6px;
431
+ }
432
+ .overview-title { font-size: 1.4rem; }
433
+ .overview-description { color: var(--demo-text-muted); }
434
+
435
+ .overview-grid {
436
+ display: grid;
437
+ grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
438
+ gap: 16px;
439
+ }
440
+ .feature-card {
441
+ background: var(--demo-surface);
442
+ border: 1px solid var(--demo-border);
443
+ border-radius: var(--demo-radius);
444
+ padding: 20px;
445
+ display: flex;
446
+ flex-direction: column;
447
+ gap: 12px;
448
+ transition: border-color 0.15s ease, box-shadow 0.15s ease;
449
+ }
450
+ .feature-card:hover {
451
+ border-color: var(--demo-border-strong);
452
+ box-shadow: var(--demo-shadow-sm);
453
+ }
454
+ .feature-icon { font-size: 1.5rem; }
455
+ .feature-card h3 { font-size: 1rem; }
456
+ .feature-list {
457
+ list-style: none;
458
+ padding: 0;
459
+ margin: 0;
460
+ display: flex;
461
+ flex-direction: column;
462
+ gap: 8px;
463
+ }
464
+ .feature-list li {
465
+ display: flex;
466
+ gap: 8px;
467
+ color: var(--demo-text);
468
+ font-size: 0.9rem;
469
+ }
470
+ .feature-dot { color: var(--demo-accent); flex-shrink: 0; font-weight: 700; }
471
+
472
+ /* ---------- Routing contract ---------- */
473
+
474
+ .contract {
475
+ display: flex;
476
+ flex-direction: column;
477
+ gap: 12px;
478
+ }
479
+ .contract__list {
480
+ list-style: none;
481
+ padding: 0;
482
+ margin: 0;
483
+ display: grid;
484
+ grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
485
+ gap: 8px;
486
+ }
487
+ .contract__list li {
488
+ background: var(--demo-surface);
489
+ border: 1px solid var(--demo-border);
490
+ border-radius: var(--demo-radius);
491
+ padding: 12px 14px;
492
+ font-size: 0.9rem;
493
+ color: var(--demo-text-muted);
494
+ }
495
+ .contract__list code {
496
+ background: var(--demo-surface-muted);
497
+ border-radius: 4px;
498
+ padding: 1px 6px;
499
+ color: var(--demo-text);
500
+ }
501
+
502
+ /* ---------- Get Started ---------- */
503
+
504
+ .get-started-section {
505
+ display: flex;
506
+ flex-direction: column;
507
+ gap: 24px;
508
+ }
509
+ .gs-header { display: flex; flex-direction: column; gap: 6px; }
510
+ .gs-title { font-size: 1.4rem; }
511
+ .gs-intro { color: var(--demo-text-muted); }
512
+
513
+ .steps-container {
514
+ display: flex;
515
+ flex-direction: column;
516
+ gap: 8px;
517
+ }
518
+ .step-item {
519
+ background: var(--demo-surface);
520
+ border: 1px solid var(--demo-border);
521
+ border-radius: var(--demo-radius);
522
+ overflow: hidden;
523
+ }
524
+ .step-header {
525
+ width: 100%;
526
+ display: flex;
527
+ align-items: center;
528
+ gap: 14px;
529
+ padding: 14px 16px;
530
+ background: transparent;
531
+ border: 0;
532
+ cursor: pointer;
533
+ text-align: left;
534
+ }
535
+ .step-header:hover { background: var(--demo-surface-muted); }
536
+ .step-header.expanded { background: var(--demo-surface-muted); }
537
+ .step-number {
538
+ flex-shrink: 0;
539
+ width: 28px;
540
+ height: 28px;
541
+ border-radius: 50%;
542
+ background: var(--demo-accent-soft);
543
+ color: var(--demo-accent);
544
+ display: flex;
545
+ align-items: center;
546
+ justify-content: center;
547
+ font-weight: 700;
548
+ font-size: 0.8rem;
549
+ }
550
+ .step-info { flex: 1; min-width: 0; }
551
+ .step-info h3 {
552
+ font-size: 0.95rem;
553
+ margin-bottom: 2px;
554
+ font-weight: 600;
555
+ }
556
+ .step-info p {
557
+ font-size: 0.85rem;
558
+ color: var(--demo-text-muted);
559
+ }
560
+ .step-toggle {
561
+ color: var(--demo-text-subtle);
562
+ font-size: 1.2rem;
563
+ flex-shrink: 0;
564
+ }
565
+ .step-content {
566
+ padding: 0 16px 16px 58px;
567
+ border-top: 1px solid var(--demo-border);
568
+ background: var(--demo-bg);
569
+ }
570
+
571
+ .code-block {
572
+ background: var(--demo-bg-elev);
573
+ border: 1px solid var(--demo-border);
574
+ color: var(--demo-text);
575
+ padding: 12px 14px;
576
+ border-radius: var(--demo-radius-sm);
577
+ overflow-x: auto;
578
+ font-family: var(--demo-mono);
579
+ font-size: 0.82rem;
580
+ margin: 12px 0 0;
581
+ }
582
+ [data-theme="dark"] .code-block {
583
+ background: #0a0c10;
584
+ }
585
+
586
+ .tips-section {
587
+ display: flex;
588
+ gap: 16px;
589
+ padding: 16px 18px;
590
+ background: var(--demo-surface);
591
+ border: 1px solid var(--demo-border);
592
+ border-left: 3px solid var(--demo-accent);
593
+ border-radius: var(--demo-radius);
594
+ }
595
+ .tips-icon { font-size: 1.4rem; }
596
+ .tips-content h3 {
597
+ font-size: 0.95rem;
598
+ margin-bottom: 6px;
599
+ }
600
+ .tips-list {
601
+ list-style: none;
602
+ padding: 0;
603
+ margin: 0;
604
+ display: flex;
605
+ flex-direction: column;
606
+ gap: 4px;
607
+ }
608
+ .tips-list li {
609
+ display: flex;
610
+ gap: 8px;
611
+ font-size: 0.9rem;
612
+ color: var(--demo-text);
613
+ }
614
+ .tips-list li::before {
615
+ content: "✓";
616
+ color: var(--demo-success);
617
+ font-weight: bold;
618
+ flex-shrink: 0;
619
+ }
620
+
621
+ /* ---------- Demo page panels ---------- */
622
+
623
+ .translations-grid {
624
+ display: grid;
625
+ grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
626
+ gap: 16px;
627
+ }
628
+ .translations-grid h3 {
629
+ font-size: 0.85rem;
630
+ text-transform: uppercase;
631
+ letter-spacing: 0.04em;
632
+ color: var(--demo-text-subtle);
633
+ margin-bottom: 10px;
634
+ }
635
+
636
+ .key-table {
637
+ width: 100%;
638
+ border-collapse: collapse;
639
+ font-size: 0.85rem;
640
+ }
641
+ .key-table th, .key-table td {
642
+ padding: 8px 10px;
643
+ text-align: left;
644
+ border-bottom: 1px solid var(--demo-border);
645
+ }
646
+ .key-table th {
647
+ color: var(--demo-text-subtle);
648
+ font-weight: 600;
649
+ font-size: 0.75rem;
650
+ text-transform: uppercase;
651
+ letter-spacing: 0.04em;
652
+ }
653
+ .key-table tr:last-child td { border-bottom: 0; }
654
+
655
+ .interpolation { display: flex; flex-direction: column; gap: 8px; }
656
+ .interpolation__row {
657
+ display: flex;
658
+ justify-content: space-between;
659
+ gap: 16px;
660
+ padding: 8px 0;
661
+ border-bottom: 1px dashed var(--demo-border);
662
+ font-size: 0.9rem;
663
+ }
664
+ .interpolation__row:last-child { border-bottom: 0; }
665
+ .interpolation__label {
666
+ color: var(--demo-text-subtle);
667
+ font-family: var(--demo-mono);
668
+ font-size: 0.8rem;
669
+ }
670
+ .interpolation__value { color: var(--demo-text); font-weight: 500; }
671
+
672
+ .status-grid {
673
+ display: grid;
674
+ grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
675
+ gap: 12px;
676
+ }
677
+ .status-card {
678
+ background: var(--demo-surface);
679
+ border: 1px solid var(--demo-border);
680
+ border-radius: var(--demo-radius);
681
+ padding: 16px;
682
+ }
683
+ .status-card h4 {
684
+ font-size: 0.7rem;
685
+ text-transform: uppercase;
686
+ letter-spacing: 0.06em;
687
+ color: var(--demo-text-subtle);
688
+ margin-bottom: 6px;
689
+ font-weight: 600;
690
+ }
691
+ .status-card p {
692
+ font-size: 0.9rem;
693
+ word-break: break-word;
694
+ }
695
+ .status-list { list-style: none; padding: 0; margin: 6px 0 0; }
696
+ .status-list li { padding: 2px 0; font-size: 0.85rem; color: var(--demo-text-muted); }
697
+
698
+ .sync-button {
699
+ margin-top: 8px;
700
+ padding: 8px 14px;
701
+ background: var(--demo-accent);
702
+ color: #fff;
703
+ border: 0;
704
+ border-radius: var(--demo-radius-sm);
705
+ cursor: pointer;
706
+ font-size: 0.85rem;
707
+ font-weight: 600;
708
+ }
709
+ .sync-button:hover:not(:disabled) { background: var(--demo-accent-hover); }
710
+ .sync-button:disabled { opacity: 0.6; cursor: not-allowed; }
711
+
712
+ .sync-result {
713
+ margin-top: 8px;
714
+ padding: 8px 12px;
715
+ border-radius: var(--demo-radius-sm);
716
+ font-size: 0.85rem;
717
+ border: 1px solid transparent;
718
+ }
719
+ .sync-result.success {
720
+ color: var(--demo-success);
721
+ border-color: rgba(22, 143, 83, 0.3);
722
+ background: rgba(22, 143, 83, 0.08);
723
+ }
724
+ .sync-result.error {
725
+ color: #c14b3a;
726
+ border-color: rgba(193, 75, 58, 0.3);
727
+ background: rgba(193, 75, 58, 0.08);
728
+ }
729
+
730
+ /* ---------- Lab (CountryLanguageDemo) ---------- */
731
+
732
+ .lab { display: flex; flex-direction: column; gap: 16px; }
733
+
734
+ .lab__status {
735
+ display: grid;
736
+ grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
737
+ gap: 16px;
738
+ padding: 16px 20px;
739
+ }
740
+ .lab__caption {
741
+ display: block;
742
+ font-size: 0.7rem;
743
+ text-transform: uppercase;
744
+ letter-spacing: 0.06em;
745
+ color: var(--demo-text-subtle);
746
+ margin-bottom: 4px;
747
+ }
748
+ .lab__value {
749
+ font-family: var(--demo-mono);
750
+ font-size: 0.9rem;
751
+ word-break: break-all;
752
+ }
753
+
754
+ .lab__grid {
755
+ display: grid;
756
+ grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
757
+ gap: 16px;
758
+ }
759
+
760
+ .lab-item {
761
+ background: var(--demo-surface);
762
+ border: 1px solid var(--demo-border);
763
+ border-radius: var(--demo-radius);
764
+ padding: 18px;
765
+ display: flex;
766
+ flex-direction: column;
767
+ gap: 14px;
768
+ }
769
+ .lab-item__head { display: flex; flex-direction: column; gap: 4px; }
770
+ .lab-item__title { font-size: 1rem; }
771
+ .lab-item__desc { font-size: 0.85rem; color: var(--demo-text-muted); }
772
+
773
+ .lab-item__body {
774
+ display: flex;
775
+ flex-direction: column;
776
+ gap: 12px;
777
+ }
778
+ .lab-item__caption {
779
+ display: block;
780
+ font-size: 0.7rem;
781
+ text-transform: uppercase;
782
+ letter-spacing: 0.06em;
783
+ color: var(--demo-text-subtle);
784
+ margin-bottom: 6px;
785
+ }
786
+ .lab-item__preview {
787
+ background: var(--demo-surface-muted);
788
+ border: 1px solid var(--demo-border);
789
+ border-radius: var(--demo-radius-sm);
790
+ padding: 14px;
791
+ display: flex;
792
+ flex-direction: column;
793
+ gap: 10px;
794
+ min-height: 64px;
795
+ }
796
+ .lab-item__code pre {
797
+ background: var(--demo-bg-elev);
798
+ border: 1px solid var(--demo-border);
799
+ border-radius: var(--demo-radius-sm);
800
+ padding: 12px;
801
+ font-size: 0.78rem;
802
+ overflow-x: auto;
803
+ margin: 0;
804
+ color: var(--demo-text);
805
+ }
806
+ [data-theme="dark"] .lab-item__code pre { background: #0a0c10; }
807
+
808
+ .lab-item__hint {
809
+ font-size: 0.85rem;
810
+ color: var(--demo-text-muted);
811
+ }
812
+
813
+ .custom-trigger {
814
+ padding: 8px 14px;
815
+ border-radius: var(--demo-radius-sm);
816
+ border: 1px solid var(--demo-border-strong);
817
+ background: var(--demo-surface);
818
+ color: var(--demo-text);
819
+ cursor: pointer;
820
+ font-size: 0.85rem;
821
+ font-weight: 500;
822
+ }
823
+ .custom-trigger[data-open="true"] {
824
+ background: var(--demo-accent-soft);
825
+ border-color: var(--demo-accent);
826
+ color: var(--demo-accent);
827
+ }
828
+
829
+ /* ---------- Logo ---------- */
830
+
831
+ .logo {
832
+ width: 32px;
833
+ height: 32px;
834
+ display: inline-flex;
835
+ align-items: center;
836
+ justify-content: center;
837
+ }
838
+ .logo img {
839
+ width: 100%;
840
+ height: 100%;
841
+ display: block;
842
+ }
843
+
844
+ /* ---------- Notices ---------- */
845
+
846
+ .notice {
847
+ margin-top: 10px;
848
+ padding: 8px 12px;
849
+ border-radius: var(--demo-radius-sm);
850
+ font-size: 0.85rem;
851
+ line-height: 1.5;
852
+ }
853
+ .notice--ok {
854
+ background: #d1fae5;
855
+ border: 1px solid #6ee7b7;
856
+ color: #065f46;
857
+ }
858
+ .notice--warn {
859
+ background: #fef3c7;
860
+ border: 1px solid #fcd34d;
861
+ color: #92400e;
862
+ }
863
+ .notice--err {
864
+ background: #fee2e2;
865
+ border: 1px solid #fca5a5;
866
+ color: #991b1b;
867
+ }
868
+ [data-theme="dark"] .notice--ok { background: #064e3b; border-color: #059669; color: #a7f3d0; }
869
+ [data-theme="dark"] .notice--warn { background: #78350f; border-color: #d97706; color: #fde68a; }
870
+ [data-theme="dark"] .notice--err { background: #7f1d1d; border-color: #dc2626; color: #fecaca; }
871
+
872
+ /* ---------- Lab item note ---------- */
873
+
874
+ .lab-item__note {
875
+ font-size: 0.82rem;
876
+ color: var(--demo-text-muted);
877
+ padding: 8px 0 0;
878
+ border-top: 1px solid var(--demo-border);
879
+ }
880
+
881
+ /* ---------- Lab status bar ---------- */
882
+
883
+ .lab__status {
884
+ display: flex;
885
+ flex-wrap: wrap;
886
+ gap: 24px;
887
+ padding: 14px 18px;
888
+ margin-bottom: 28px;
889
+ }
890
+ .lab__status > div { display: flex; flex-direction: column; gap: 2px; }
891
+ .lab__caption {
892
+ font-size: 0.75rem;
893
+ text-transform: uppercase;
894
+ letter-spacing: 0.06em;
895
+ color: var(--demo-text-muted);
896
+ }
897
+ .lab__value { font-size: 0.9rem; font-weight: 600; }
898
+
899
+ /* ---------- Lab side-by-side ---------- */
900
+
901
+ .lab__side-by-side {
902
+ display: grid;
903
+ grid-template-columns: 1fr 1fr;
904
+ gap: 20px;
905
+ margin-bottom: 32px;
906
+ }
907
+ @media (max-width: 800px) {
908
+ .lab__side-by-side { grid-template-columns: 1fr; }
909
+ }
910
+
911
+ .lab__side {
912
+ display: flex;
913
+ flex-direction: column;
914
+ gap: 14px;
915
+ padding: 20px;
916
+ }
917
+ .lab__side-title { font-size: 1rem; font-weight: 700; margin: 0; }
918
+ .lab__side-desc { font-size: 0.88rem; color: var(--demo-text-muted); margin: 0; }
919
+ .lab__outcome {
920
+ font-size: 0.85rem;
921
+ color: var(--demo-text-muted);
922
+ padding-top: 8px;
923
+ border-top: 1px dashed var(--demo-border);
924
+ }
925
+
926
+ /* ---------- Scenarios ---------- */
927
+
928
+ .lab__scenarios {
929
+ padding-top: 8px;
930
+ }
931
+ .lab__scenarios h3 { font-size: 1rem; margin-bottom: 8px; }
932
+ .lab__scenarios > p { font-size: 0.88rem; color: var(--demo-text-muted); margin-bottom: 16px; }
933
+
934
+ .scenario-grid {
935
+ display: grid;
936
+ grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
937
+ gap: 12px;
938
+ }
939
+
940
+ .scenario-card {
941
+ display: flex;
942
+ flex-direction: column;
943
+ gap: 6px;
944
+ padding: 14px 16px;
945
+ background: var(--demo-surface);
946
+ border: 1px solid var(--demo-border);
947
+ border-radius: var(--demo-radius);
948
+ cursor: pointer;
949
+ text-align: left;
950
+ transition: border-color .15s, background .15s;
951
+ }
952
+ .scenario-card:hover {
953
+ border-color: var(--demo-accent);
954
+ background: var(--demo-accent-soft);
955
+ }
956
+ .scenario-card__action { font-size: 0.88rem; font-weight: 600; }
957
+ .scenario-card__result, .scenario-card__start { font-size: 0.8rem; color: var(--demo-text-muted); }
958
+ .scenario-card code { font-size: 0.78rem; }
959
+
960
+ /* ---------- Switcher distinction box ---------- */
961
+
962
+ .switcher-distinction {
963
+ padding: 18px 20px;
964
+ margin-bottom: 20px;
965
+ }
966
+ .switcher-distinction h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 8px; }
967
+ .switcher-distinction p { font-size: 0.88rem; color: var(--demo-text-muted); margin-bottom: 8px; }
968
+ .slug-list {
969
+ list-style: none;
970
+ padding: 0;
971
+ margin: 0;
972
+ display: flex;
973
+ flex-wrap: wrap;
974
+ gap: 8px;
975
+ }
976
+ .slug-list li {
977
+ background: var(--demo-surface-muted);
978
+ border-radius: var(--demo-radius-sm);
979
+ padding: 4px 10px;
980
+ font-size: 0.85rem;
981
+ }
982
+
983
+ /* ---------- Comparison table ---------- */
984
+
985
+ .comparison-table {
986
+ padding: 18px 20px;
987
+ margin-bottom: 28px;
988
+ }
989
+ .comparison-table h3 { font-size: 0.95rem; font-weight: 700; margin-bottom: 12px; }
990
+ .tbl-wrap { overflow-x: auto; }
991
+ .comparison-table table {
992
+ width: 100%;
993
+ border-collapse: collapse;
994
+ font-size: 0.85rem;
995
+ }
996
+ .comparison-table th,
997
+ .comparison-table td {
998
+ text-align: left;
999
+ padding: 8px 12px;
1000
+ border-bottom: 1px solid var(--demo-border);
1001
+ }
1002
+ .comparison-table th {
1003
+ background: var(--demo-surface-muted);
1004
+ font-weight: 600;
1005
+ color: var(--demo-text-muted);
1006
+ text-transform: uppercase;
1007
+ letter-spacing: 0.05em;
1008
+ font-size: 0.78rem;
1009
+ }
1010
+ .comparison-table td.yes { color: #059669; font-weight: 600; }
1011
+ .comparison-table td.no { color: #dc2626; }
1012
+ [data-theme="dark"] .comparison-table td.yes { color: #34d399; }
1013
+ [data-theme="dark"] .comparison-table td.no { color: #f87171; }
1014
+
1015
+ /* ---------- Locale chip sub-parts ---------- */
1016
+
1017
+ .locale-chip__dot {
1018
+ width: 7px;
1019
+ height: 7px;
1020
+ border-radius: 50%;
1021
+ background: var(--demo-accent);
1022
+ flex-shrink: 0;
1023
+ }
1024
+ .locale-chip__slug {
1025
+ font-size: 0.72rem;
1026
+ color: var(--demo-text-muted);
1027
+ font-family: var(--demo-mono);
1028
+ border-left: 1px solid var(--demo-border);
1029
+ padding-left: 6px;
1030
+ margin-left: 2px;
1031
+ }
1032
+
1033
+ /* ---------- Responsive ---------- */
1034
+
1035
+ @media (max-width: 1024px) {
1036
+ .topnav__inner {
1037
+ grid-template-columns: 1fr auto;
1038
+ grid-template-areas:
1039
+ "brand actions"
1040
+ "pills pills";
1041
+ gap: 12px;
1042
+ }
1043
+ .topnav__brand { grid-area: brand; }
1044
+ .topnav__actions { grid-area: actions; }
1045
+ .topnav__pills { grid-area: pills; justify-content: flex-start; }
1046
+
1047
+ .hero {
1048
+ grid-template-columns: 1fr;
1049
+ }
1050
+ }
1051
+
1052
+ @media (max-width: 640px) {
1053
+ .app-main { padding: 20px 16px 48px; gap: 32px; }
1054
+
1055
+ .topnav__inner { padding: 10px 14px; }
1056
+ .topnav__brand-tag { display: none; }
1057
+
1058
+ .topnav__actions { gap: 6px; }
1059
+ .locale-chip { display: none; }
1060
+
1061
+ .url-card__grid { grid-template-columns: 1fr 1fr; }
1062
+
1063
+ .step-content { padding-left: 16px; }
1064
+
1065
+ .interpolation__row {
1066
+ flex-direction: column;
1067
+ gap: 4px;
1068
+ }
1069
+ }
1070
+
1071
+ @media (max-width: 420px) {
1072
+ .topnav__brand-name { font-size: 0.8rem; }
1073
+ .pill { padding: 6px 9px; font-size: 0.78rem; }
1074
+ .url-card__grid { grid-template-columns: 1fr; }
1075
+ }