@dodlhuat/basix 1.3.1 → 1.3.3

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 (118) hide show
  1. package/README.md +14 -8
  2. package/css/accordion.scss +0 -5
  3. package/css/badge.scss +1 -6
  4. package/css/bottom-sheet.scss +3 -8
  5. package/css/breadcrumb.scss +6 -15
  6. package/css/button.scss +2 -1
  7. package/css/calendar.scss +0 -67
  8. package/css/card.scss +0 -5
  9. package/css/carousel.scss +0 -3
  10. package/css/chart.scss +0 -25
  11. package/css/chat-bubbles.scss +0 -15
  12. package/css/checkbox.scss +3 -2
  13. package/css/chips.scss +3 -7
  14. package/css/code-viewer.scss +1 -5
  15. package/css/context-menu.scss +5 -21
  16. package/css/datepicker.scss +6 -9
  17. package/css/docs.scss +0 -4
  18. package/css/dropdown.scss +1 -1
  19. package/css/editor.scss +1 -23
  20. package/css/file-uploader.scss +2 -2
  21. package/css/flyout-menu.scss +65 -58
  22. package/css/form.scss +0 -28
  23. package/css/gallery.scss +2 -3
  24. package/css/group-picker.scss +5 -35
  25. package/css/icons.scss +0 -3
  26. package/css/lightbox.scss +2 -4
  27. package/css/mixins.scss +8 -0
  28. package/css/modal.scss +3 -3
  29. package/css/parameters.scss +6 -1
  30. package/css/popover.scss +3 -15
  31. package/css/progress.scss +0 -6
  32. package/css/push-menu.scss +3 -28
  33. package/css/radiobutton.scss +2 -1
  34. package/css/range-slider.scss +1 -7
  35. package/css/scrollbar.scss +9 -16
  36. package/css/sidebar-nav.scss +0 -12
  37. package/css/stepper.scss +0 -4
  38. package/css/style.css +108 -116
  39. package/css/style.css.map +1 -1
  40. package/css/style.min.css +1 -1
  41. package/css/style.min.css.map +1 -1
  42. package/css/style.scss +1 -1
  43. package/css/table.scss +0 -4
  44. package/css/tabs.scss +0 -2
  45. package/css/timeline.scss +1 -13
  46. package/css/timepicker.scss +55 -39
  47. package/css/toast.scss +1 -1
  48. package/css/tooltip.scss +1 -5
  49. package/css/tree.scss +1 -1
  50. package/css/typography.scss +3 -3
  51. package/css/virtual-dropdown.scss +3 -28
  52. package/js/bottom-sheet.d.ts +3 -1
  53. package/js/bottom-sheet.js +26 -27
  54. package/js/calendar.d.ts +7 -0
  55. package/js/calendar.js +14 -33
  56. package/js/carousel.d.ts +2 -0
  57. package/js/carousel.js +13 -5
  58. package/js/chart.d.ts +4 -0
  59. package/js/chart.js +13 -31
  60. package/js/code-viewer.d.ts +1 -0
  61. package/js/code-viewer.js +4 -0
  62. package/js/context-menu.d.ts +9 -2
  63. package/js/context-menu.js +17 -14
  64. package/js/datepicker.d.ts +4 -0
  65. package/js/datepicker.js +26 -11
  66. package/js/dropdown.d.ts +3 -3
  67. package/js/dropdown.js +6 -9
  68. package/js/editor.d.ts +1 -1
  69. package/js/editor.js +14 -20
  70. package/js/file-uploader.d.ts +4 -0
  71. package/js/file-uploader.js +52 -43
  72. package/js/flyout-menu.d.ts +5 -3
  73. package/js/flyout-menu.js +23 -46
  74. package/js/gallery.d.ts +4 -0
  75. package/js/gallery.js +39 -50
  76. package/js/group-picker.d.ts +5 -0
  77. package/js/group-picker.js +12 -17
  78. package/js/lightbox.d.ts +3 -0
  79. package/js/lightbox.js +12 -6
  80. package/js/modal.d.ts +3 -1
  81. package/js/modal.js +14 -11
  82. package/js/popover.d.ts +2 -0
  83. package/js/popover.js +26 -30
  84. package/js/position.d.ts +2 -0
  85. package/js/position.js +1 -5
  86. package/js/push-menu.d.ts +2 -1
  87. package/js/push-menu.js +25 -48
  88. package/js/range-slider.d.ts +1 -0
  89. package/js/range-slider.js +5 -3
  90. package/js/scroll.d.ts +2 -0
  91. package/js/scroll.js +1 -0
  92. package/js/scrollbar.d.ts +2 -0
  93. package/js/scrollbar.js +24 -36
  94. package/js/select.d.ts +1 -0
  95. package/js/select.js +5 -10
  96. package/js/sidebar-nav.d.ts +2 -0
  97. package/js/sidebar-nav.js +8 -0
  98. package/js/stepper.d.ts +2 -0
  99. package/js/stepper.js +7 -1
  100. package/js/table.d.ts +4 -0
  101. package/js/table.js +15 -22
  102. package/js/tabs.d.ts +2 -0
  103. package/js/tabs.js +6 -14
  104. package/js/theme.d.ts +1 -0
  105. package/js/theme.js +5 -13
  106. package/js/timepicker.d.ts +22 -5
  107. package/js/timepicker.js +160 -57
  108. package/js/toast.d.ts +3 -1
  109. package/js/toast.js +25 -22
  110. package/js/tooltip.d.ts +2 -0
  111. package/js/tooltip.js +21 -19
  112. package/js/tree.d.ts +3 -0
  113. package/js/tree.js +13 -0
  114. package/js/utils.d.ts +1 -3
  115. package/js/utils.js +0 -3
  116. package/js/virtual-dropdown.d.ts +3 -0
  117. package/js/virtual-dropdown.js +25 -0
  118. package/package.json +2 -2
package/css/style.css CHANGED
@@ -500,7 +500,6 @@ a:focus-visible {
500
500
  padding: 2rem;
501
501
  }
502
502
 
503
- /* Controls */
504
503
  .table-controls {
505
504
  display: flex;
506
505
  justify-content: space-between;
@@ -510,7 +509,6 @@ a:focus-visible {
510
509
  gap: 0.75rem;
511
510
  }
512
511
 
513
- /* Table Styles */
514
512
  .table-wrapper {
515
513
  overflow-x: auto;
516
514
  border: 1px solid var(--divider);
@@ -578,7 +576,6 @@ tbody tr:hover {
578
576
  background-color: var(--hover);
579
577
  }
580
578
 
581
- /* Pagination */
582
579
  .pagination {
583
580
  display: flex;
584
581
  justify-content: space-between;
@@ -630,7 +627,6 @@ tbody tr:hover {
630
627
  cursor: not-allowed;
631
628
  }
632
629
 
633
- /* Mobile Responsive Styles */
634
630
  @media (max-width: 768px) {
635
631
  .table-controls {
636
632
  flex-direction: column;
@@ -1556,18 +1552,16 @@ input.input-lg, textarea.input-lg {
1556
1552
  width: 100%;
1557
1553
  overflow: auto;
1558
1554
  box-sizing: border-box;
1559
- }
1560
- .scroll-container .viewport .content {
1561
- margin: 0;
1562
- margin-right: calc(var(--track-width) + var(--track-gap));
1555
+ scrollbar-width: none;
1556
+ -ms-overflow-style: none;
1563
1557
  }
1564
1558
  .scroll-container .viewport::-webkit-scrollbar {
1565
1559
  width: 0;
1566
1560
  height: 0;
1567
1561
  }
1568
- .scroll-container .viewport {
1569
- scrollbar-width: none;
1570
- -ms-overflow-style: none;
1562
+ .scroll-container .viewport .content {
1563
+ margin: 0;
1564
+ margin-right: calc(var(--track-width) + var(--track-gap));
1571
1565
  }
1572
1566
  .scroll-container .scrollbar {
1573
1567
  position: absolute;
@@ -3855,7 +3849,7 @@ ul.tree li {
3855
3849
  user-select: none;
3856
3850
  box-shadow: 0 1px 2px rgba(56, 65, 74, 0.15);
3857
3851
  display: none;
3858
- position: absolute;
3852
+ position: fixed;
3859
3853
  z-index: 1000;
3860
3854
  box-sizing: border-box;
3861
3855
  }
@@ -3926,7 +3920,7 @@ ul.tree li {
3926
3920
  font-size: 1rem;
3927
3921
  cursor: pointer;
3928
3922
  border-radius: 0.4rem;
3929
- transition: all 0.2s;
3923
+ transition: background-color 0.2s, color 0.2s;
3930
3924
  }
3931
3925
 
3932
3926
  .datepicker-day:hover:not(.disabled) {
@@ -3986,7 +3980,7 @@ ul.tree li {
3986
3980
  font-size: 0.9rem;
3987
3981
  cursor: pointer;
3988
3982
  border-radius: 0.4rem;
3989
- transition: all 0.2s;
3983
+ transition: background-color 0.2s, color 0.2s;
3990
3984
  }
3991
3985
 
3992
3986
  .datepicker-month:hover,
@@ -4028,7 +4022,6 @@ ul.tree li {
4028
4022
  background-color: var(--accent-color-lighten);
4029
4023
  }
4030
4024
 
4031
- /* Time Picker */
4032
4025
  .datepicker-time {
4033
4026
  display: flex;
4034
4027
  align-items: center;
@@ -4102,7 +4095,6 @@ ul.tree li {
4102
4095
  outline-offset: -1px;
4103
4096
  }
4104
4097
 
4105
- /* Set Button */
4106
4098
  .datepicker-set-btn {
4107
4099
  width: 100%;
4108
4100
  padding: 0.5rem 1rem;
@@ -4121,7 +4113,6 @@ ul.tree li {
4121
4113
  opacity: 0.9;
4122
4114
  }
4123
4115
 
4124
- /* Mobile Responsiveness */
4125
4116
  @media (max-width: 640px) {
4126
4117
  .datepicker-backdrop {
4127
4118
  position: fixed;
@@ -4164,9 +4155,6 @@ ul.tree li {
4164
4155
  padding: 0.75rem 0;
4165
4156
  }
4166
4157
  }
4167
- /* Flyout menu uses its own dark palette intentionally —
4168
- it renders over any background regardless of light/dark mode.
4169
- Scoped here rather than polluting :root. */
4170
4158
  .flyout-menu,
4171
4159
  .flyout-overlay,
4172
4160
  .site-header,
@@ -4192,7 +4180,6 @@ body {
4192
4180
  min-height: 100vh;
4193
4181
  }
4194
4182
 
4195
- /* Header */
4196
4183
  .site-header {
4197
4184
  display: flex;
4198
4185
  justify-content: space-between;
@@ -4246,7 +4233,6 @@ body {
4246
4233
  font-size: 1.2rem;
4247
4234
  }
4248
4235
 
4249
- /* Flyout Overlay */
4250
4236
  .flyout-overlay {
4251
4237
  position: fixed;
4252
4238
  top: 0;
@@ -4266,22 +4252,19 @@ body {
4266
4252
  visibility: visible;
4267
4253
  }
4268
4254
 
4269
- /* Flyout Menu Base */
4270
4255
  .flyout-menu {
4271
4256
  position: fixed;
4272
- background: var(--flyout-bg);
4273
- backdrop-filter: blur(20px);
4274
- -webkit-backdrop-filter: blur(20px);
4257
+ background: rgba(10, 15, 30, 0.82);
4258
+ backdrop-filter: blur(28px) saturate(1.4);
4259
+ -webkit-backdrop-filter: blur(28px) saturate(1.4);
4275
4260
  z-index: 210;
4276
4261
  display: flex;
4277
4262
  flex-direction: column;
4278
- padding: 2rem;
4279
- box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
4263
+ padding: 1.75rem 1.5rem;
4264
+ box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06), 0 32px 80px rgba(0, 0, 0, 0.6);
4280
4265
  transition: transform var(--transition-speed) cubic-bezier(0.25, 1, 0.5, 1);
4281
- /* Smoother rollout */
4282
4266
  }
4283
4267
 
4284
- /* Directional Variants */
4285
4268
  .flyout-from-right {
4286
4269
  top: 0;
4287
4270
  right: 0;
@@ -4304,37 +4287,53 @@ body {
4304
4287
  transform: translate(0, 0);
4305
4288
  }
4306
4289
 
4307
- /* Flyout Header */
4308
4290
  .flyout-header {
4309
4291
  display: flex;
4310
4292
  justify-content: space-between;
4311
4293
  align-items: center;
4312
- margin-bottom: 3rem;
4294
+ margin-bottom: 2.5rem;
4295
+ padding-bottom: 1.25rem;
4296
+ border-bottom: 1px solid rgba(255, 255, 255, 0.07);
4313
4297
  }
4314
4298
 
4315
4299
  .flyout-title {
4316
- font-size: 1.25rem;
4300
+ font-size: 0.65rem;
4317
4301
  font-weight: 600;
4318
- color: #94a3b8;
4302
+ color: rgba(255, 255, 255, 0.35);
4319
4303
  text-transform: uppercase;
4320
- letter-spacing: 0.1em;
4304
+ letter-spacing: 0.14em;
4321
4305
  }
4322
4306
 
4323
4307
  .close-menu {
4324
4308
  background: none;
4325
4309
  border: none;
4326
- color: var(--flyout-text);
4310
+ color: rgba(255, 255, 255, 0.4);
4327
4311
  cursor: pointer;
4328
- padding: 0.5rem;
4329
- transition: transform 0.2s, color 0.2s;
4312
+ padding: 0.3rem;
4313
+ line-height: 0;
4314
+ transition: color 0.2s;
4330
4315
  }
4331
4316
 
4332
4317
  .close-menu:hover {
4333
- transform: rotate(90deg);
4334
- color: var(--accent-color);
4318
+ color: #fff;
4319
+ }
4320
+
4321
+ .flyout-menu button {
4322
+ display: flex;
4323
+ padding: 0;
4324
+ border-radius: 0;
4325
+ background: none;
4326
+ font-size: inherit;
4327
+ font-weight: inherit;
4328
+ white-space: normal;
4329
+ transition: color 0.2s;
4330
+ }
4331
+ .flyout-menu button:hover:not(:disabled), .flyout-menu button:active:not(:disabled), .flyout-menu button.active {
4332
+ background: none;
4333
+ transform: none;
4334
+ box-shadow: none;
4335
4335
  }
4336
4336
 
4337
- /* Flyout Links */
4338
4337
  .flyout-links {
4339
4338
  list-style: none;
4340
4339
  flex-grow: 1;
@@ -4355,7 +4354,7 @@ body {
4355
4354
  border: none;
4356
4355
  font-size: 2rem;
4357
4356
  font-weight: 600;
4358
- color: var(--flyout-text);
4357
+ color: rgba(255, 255, 255, 0.6);
4359
4358
  text-decoration: none;
4360
4359
  cursor: pointer;
4361
4360
  font-family: inherit;
@@ -4371,38 +4370,40 @@ body {
4371
4370
  transform: translateY(0);
4372
4371
  }
4373
4372
 
4374
- .flyout-links a:hover,
4375
- .submenu-toggle:hover {
4373
+ .flyout-links > li > a:hover,
4374
+ .flyout-links > li > .submenu-toggle:hover {
4375
+ color: #fff;
4376
+ }
4377
+
4378
+ .submenu-toggle.active {
4376
4379
  color: var(--accent-color);
4377
4380
  }
4378
4381
 
4379
4382
  .chevron {
4380
- transition: transform 0.3s;
4381
- opacity: 0.7;
4383
+ flex-shrink: 0;
4384
+ opacity: 0.5;
4385
+ transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s;
4382
4386
  }
4383
4387
 
4384
4388
  .submenu-toggle.active .chevron {
4385
4389
  transform: rotate(180deg);
4390
+ opacity: 1;
4386
4391
  }
4387
4392
 
4388
- /* Submenu */
4389
4393
  .submenu {
4390
4394
  list-style: none;
4391
4395
  max-height: 0;
4392
4396
  overflow: hidden;
4393
4397
  transition: max-height 0.3s ease-out;
4394
4398
  padding-left: 1rem;
4395
- border-left: 1px solid rgba(255, 255, 255, 0.1);
4399
+ border-left: 1px solid rgba(255, 255, 255, 0.15);
4396
4400
  margin-top: 0;
4397
4401
  }
4398
4402
 
4399
4403
  .submenu.is-open {
4400
4404
  max-height: 500px;
4401
- /* Reduced from 2000px for tighter animation */
4402
- /* Arbitrary large height, increased for nesting */
4403
4405
  margin-top: 1rem;
4404
4406
  transition: max-height 0.4s cubic-bezier(0.16, 1, 0.3, 1);
4405
- /* Smoother easing */
4406
4407
  }
4407
4408
 
4408
4409
  .submenu li {
@@ -4412,30 +4413,36 @@ body {
4412
4413
  .submenu a {
4413
4414
  font-size: 1.25rem;
4414
4415
  font-weight: 400;
4415
- color: #cbd5e1;
4416
+ color: rgba(255, 255, 255, 0.45);
4416
4417
  transform: none !important;
4417
- /* Override slide-in for submenu items */
4418
+ transition: color 0.2s !important;
4418
4419
  transition-delay: 0s !important;
4419
4420
  }
4421
+ .submenu a:hover {
4422
+ color: #fff;
4423
+ }
4420
4424
 
4421
4425
  .submenu .submenu-toggle {
4422
4426
  font-size: 1.25rem;
4423
4427
  font-weight: 400;
4424
- color: #cbd5e1;
4428
+ color: rgba(255, 255, 255, 0.45);
4425
4429
  transform: none !important;
4426
4430
  transition-delay: 0s !important;
4427
4431
  padding: 0;
4428
4432
  margin: 0;
4429
4433
  }
4434
+ .submenu .submenu-toggle:hover {
4435
+ color: #fff;
4436
+ }
4430
4437
 
4431
- /* Flyout Footer */
4432
4438
  .flyout-footer {
4433
- padding-top: 2rem;
4434
- border-top: 1px solid var(--flyout-border);
4435
- color: #64748b;
4436
- font-size: 0.9rem;
4439
+ padding-top: 1.25rem;
4440
+ border-top: 1px solid rgba(255, 255, 255, 0.07);
4441
+ color: rgba(255, 255, 255, 0.25);
4442
+ font-size: 0.72rem;
4443
+ letter-spacing: 0.03em;
4437
4444
  opacity: 0;
4438
- transform: translateY(20px);
4445
+ transform: translateY(12px);
4439
4446
  transition: opacity 0.4s, transform 0.4s;
4440
4447
  transition-delay: var(--delay);
4441
4448
  }
@@ -4445,7 +4452,6 @@ body {
4445
4452
  transform: translateY(0);
4446
4453
  }
4447
4454
 
4448
- /* Mobile Responsiveness */
4449
4455
  @media (max-width: 480px) {
4450
4456
  :root {
4451
4457
  --menu-width: 100%;
@@ -4453,7 +4459,6 @@ body {
4453
4459
  .main-content h1 {
4454
4460
  font-size: 2rem;
4455
4461
  }
4456
- /* Force Fullscreen for all directions */
4457
4462
  .flyout-from-right,
4458
4463
  .flyout-from-left,
4459
4464
  .flyout-from-top {
@@ -4464,22 +4469,12 @@ body {
4464
4469
  right: auto !important;
4465
4470
  bottom: auto !important;
4466
4471
  border: none !important;
4467
- /* Remove borders for cleaner fullscreen look */
4468
4472
  border-right: 1px solid var(--flyout-border) !important;
4469
- /* Add consistent right border */
4470
- transform: translateX(-100%) !important;
4471
- /* Force ALL to slide from LEFT with !important */
4472
- }
4473
- /* Remove specific transforms and force left slide */
4474
- .flyout-from-right,
4475
- .flyout-from-left,
4476
- .flyout-from-top {
4477
4473
  transform: translateX(-100%) !important;
4478
4474
  }
4479
4475
  .flyout-menu.is-open {
4480
4476
  transform: translate(0, 0) !important;
4481
4477
  }
4482
- /* Reset Top Menu Horizontal Layout to Vertical for Mobile */
4483
4478
  .flyout-from-top .flyout-links {
4484
4479
  flex-direction: column;
4485
4480
  align-items: stretch;
@@ -4491,7 +4486,6 @@ body {
4491
4486
  .flyout-from-top .flyout-links > li > a,
4492
4487
  .flyout-from-top .flyout-links > li > .submenu-toggle {
4493
4488
  font-size: 2rem;
4494
- /* Restore larger size */
4495
4489
  justify-content: space-between;
4496
4490
  }
4497
4491
  .flyout-from-top .submenu {
@@ -4513,7 +4507,6 @@ body {
4513
4507
  .flyout-from-top .submenu a {
4514
4508
  font-size: 1.25rem;
4515
4509
  justify-content: space-between;
4516
- /* Match default behavior */
4517
4510
  }
4518
4511
  }
4519
4512
  .tabs-container {
@@ -5102,7 +5095,6 @@ body {
5102
5095
  color: #d4d4d4;
5103
5096
  }
5104
5097
 
5105
- /* Syntax Highlighting — VS Code Dark+ palette */
5106
5098
  .keyword {
5107
5099
  color: #569cd6;
5108
5100
  }
@@ -5917,6 +5909,8 @@ body {
5917
5909
  border-radius: 99px;
5918
5910
  overflow: visible;
5919
5911
  position: relative;
5912
+ touch-action: none;
5913
+ user-select: none;
5920
5914
  }
5921
5915
 
5922
5916
  .timespan-bar-fill {
@@ -5926,10 +5920,24 @@ body {
5926
5920
  height: 100%;
5927
5921
  background: var(--accent-color);
5928
5922
  border-radius: inherit;
5923
+ touch-action: none;
5929
5924
  transition: left 0.3s cubic-bezier(0.2, 0, 0, 1), width 0.3s cubic-bezier(0.2, 0, 0, 1);
5930
5925
  }
5931
- .timespan-bar-fill::before, .timespan-bar-fill::after {
5932
- content: "";
5926
+ .timespan-bar-fill.is-active {
5927
+ cursor: grab;
5928
+ }
5929
+ .timespan-bar-fill.is-active:active {
5930
+ cursor: grabbing;
5931
+ }
5932
+ .timespan-picker.is-error ~ .timespan-bar .timespan-bar-fill {
5933
+ background: var(--error);
5934
+ }
5935
+
5936
+ .timespan-bar.is-dragging .timespan-bar-fill {
5937
+ transition: none;
5938
+ }
5939
+
5940
+ .timespan-handle {
5933
5941
  position: absolute;
5934
5942
  top: 50%;
5935
5943
  width: 12px;
@@ -5938,23 +5946,29 @@ body {
5938
5946
  background: var(--accent-color);
5939
5947
  border: 2px solid var(--background);
5940
5948
  transform: translateY(-50%);
5941
- transition: transform 0.2s ease, box-shadow 0.2s ease;
5942
5949
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
5950
+ cursor: ew-resize;
5951
+ touch-action: none;
5943
5952
  opacity: 0;
5953
+ pointer-events: none;
5954
+ transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
5944
5955
  }
5945
- .timespan-bar-fill::before {
5946
- left: -6px;
5956
+ .timespan-bar-fill.is-active .timespan-handle {
5957
+ opacity: 1;
5958
+ pointer-events: auto;
5947
5959
  }
5948
- .timespan-bar-fill::after {
5949
- right: -6px;
5960
+ .timespan-handle:hover {
5961
+ transform: translateY(-50%) scale(1.3);
5962
+ box-shadow: 0 0 0 6px color-mix(in srgb, var(--accent-color) 15%, transparent);
5950
5963
  }
5951
- .timespan-bar-fill[style*=width]:not([style*="width: 0"]):not([style*="width:0"])::before, .timespan-bar-fill[style*=width]:not([style*="width: 0"]):not([style*="width:0"])::after {
5952
- opacity: 1;
5964
+ .timespan-handle.timespan-handle-start {
5965
+ left: -6px;
5953
5966
  }
5954
- .timespan-picker.is-error ~ .timespan-bar .timespan-bar-fill {
5955
- background: var(--error);
5967
+ .timespan-handle.timespan-handle-end {
5968
+ right: -6px;
5969
+ left: auto;
5956
5970
  }
5957
- .timespan-picker.is-error ~ .timespan-bar .timespan-bar-fill::before, .timespan-picker.is-error ~ .timespan-bar .timespan-bar-fill::after {
5971
+ .timespan-picker.is-error ~ .timespan-bar .timespan-handle {
5958
5972
  background: var(--error);
5959
5973
  }
5960
5974
 
@@ -6103,7 +6117,6 @@ body {
6103
6117
  cursor: not-allowed;
6104
6118
  }
6105
6119
 
6106
- /* ── Editor Component ───────────────────────────────────────────────── */
6107
6120
  .editor {
6108
6121
  background: var(--secondary-background);
6109
6122
  border: 1px solid var(--divider);
@@ -6114,7 +6127,6 @@ body {
6114
6127
  overflow: hidden;
6115
6128
  }
6116
6129
 
6117
- /* ── Toolbar ───────────────────────────────────────────────────────── */
6118
6130
  .editor-toolbar {
6119
6131
  display: flex;
6120
6132
  align-items: center;
@@ -6130,7 +6142,6 @@ body {
6130
6142
  display: none;
6131
6143
  }
6132
6144
 
6133
- /* SVG icon sizing */
6134
6145
  .editor-toolbar .icon-svg {
6135
6146
  fill: currentColor;
6136
6147
  display: block;
@@ -6140,7 +6151,6 @@ body {
6140
6151
  flex-shrink: 0;
6141
6152
  }
6142
6153
 
6143
- /* Button base */
6144
6154
  .editor-toolbar button {
6145
6155
  display: inline-flex;
6146
6156
  align-items: center;
@@ -6183,7 +6193,6 @@ body {
6183
6193
  background: var(--accent-color);
6184
6194
  }
6185
6195
 
6186
- /* Button clusters — pill-shaped groups */
6187
6196
  .toolbar-group {
6188
6197
  display: flex;
6189
6198
  align-items: center;
@@ -6197,7 +6206,6 @@ body {
6197
6206
  border-radius: 0.18rem;
6198
6207
  }
6199
6208
 
6200
- /* Block-format select — reset all global form overrides */
6201
6209
  .editor-block-select {
6202
6210
  width: auto;
6203
6211
  flex-shrink: 0;
@@ -6230,13 +6238,11 @@ body {
6230
6238
  font-weight: 400;
6231
6239
  }
6232
6240
 
6233
- /* Separators: invisible spacers — visual grouping comes from .toolbar-group */
6234
6241
  .toolbar-separator {
6235
6242
  width: 0.35rem;
6236
6243
  flex-shrink: 0;
6237
6244
  }
6238
6245
 
6239
- /* Right-pinned actions */
6240
6246
  .toolbar-end {
6241
6247
  display: flex;
6242
6248
  align-items: center;
@@ -6249,7 +6255,6 @@ body {
6249
6255
  display: none;
6250
6256
  }
6251
6257
 
6252
- /* Variant button states — scoped to avoid !important */
6253
6258
  .editor-toolbar button.toolbar-btn-accent {
6254
6259
  background: color-mix(in srgb, var(--accent-color) 10%, transparent);
6255
6260
  color: var(--accent-color);
@@ -6263,7 +6268,6 @@ body {
6263
6268
  color: var(--error);
6264
6269
  }
6265
6270
 
6266
- /* ── Editor Body ───────────────────────────────────────────────────── */
6267
6271
  .editor-body {
6268
6272
  display: flex;
6269
6273
  flex: 1;
@@ -6357,7 +6361,6 @@ body {
6357
6361
  font-weight: 700;
6358
6362
  }
6359
6363
 
6360
- /* ── Side Panel ────────────────────────────────────────────────────── */
6361
6364
  .editor-side {
6362
6365
  width: 320px;
6363
6366
  min-width: 240px;
@@ -6503,7 +6506,6 @@ body {
6503
6506
  text-underline-offset: 2px;
6504
6507
  }
6505
6508
 
6506
- /* ── Footer ────────────────────────────────────────────────────────── */
6507
6509
  .editor-footer {
6508
6510
  display: flex;
6509
6511
  align-items: center;
@@ -6547,7 +6549,6 @@ body {
6547
6549
  box-shadow: 0 1px 0 var(--divider);
6548
6550
  }
6549
6551
 
6550
- /* ── Responsive ────────────────────────────────────────────────────── */
6551
6552
  @media screen and (max-width: 768px) {
6552
6553
  .editor-body {
6553
6554
  flex-direction: column;
@@ -6591,7 +6592,6 @@ body {
6591
6592
  display: none;
6592
6593
  }
6593
6594
  }
6594
- /* ── Link Popover ──────────────────────────────────────────────────── */
6595
6595
  .editor-link-popover {
6596
6596
  display: flex;
6597
6597
  flex-direction: column;
@@ -6911,9 +6911,10 @@ body {
6911
6911
  color: var(--secondary-text);
6912
6912
  transition: color 0.1s ease;
6913
6913
  }
6914
- .context-menu-item .context-menu-icon .icon-svg {
6914
+ .context-menu-item .context-menu-icon svg {
6915
6915
  width: 1rem;
6916
6916
  height: 1rem;
6917
+ fill: currentColor;
6917
6918
  }
6918
6919
  .context-menu-item .context-menu-label {
6919
6920
  flex: 1;
@@ -6937,25 +6938,14 @@ body {
6937
6938
  margin-left: 0.25rem;
6938
6939
  color: var(--secondary-text);
6939
6940
  }
6940
- .context-menu-item:hover, .context-menu-item.is-focused {
6941
- background: var(--secondary-background);
6942
- color: var(--accent-color);
6943
- }
6944
- .context-menu-item:hover .context-menu-icon, .context-menu-item.is-focused .context-menu-icon {
6945
- color: var(--accent-color);
6946
- }
6947
- .context-menu-item:hover .context-menu-chevron, .context-menu-item.is-focused .context-menu-chevron {
6948
- color: var(--accent-color);
6949
- opacity: 0.8;
6950
- }
6951
- .context-menu-item.is-active {
6941
+ .context-menu-item:hover, .context-menu-item.is-focused, .context-menu-item.is-active {
6952
6942
  background: var(--secondary-background);
6953
6943
  color: var(--accent-color);
6954
6944
  }
6955
- .context-menu-item.is-active .context-menu-icon {
6945
+ .context-menu-item:hover .context-menu-icon, .context-menu-item.is-focused .context-menu-icon, .context-menu-item.is-active .context-menu-icon {
6956
6946
  color: var(--accent-color);
6957
6947
  }
6958
- .context-menu-item.is-active .context-menu-chevron {
6948
+ .context-menu-item:hover .context-menu-chevron, .context-menu-item.is-focused .context-menu-chevron, .context-menu-item.is-active .context-menu-chevron {
6959
6949
  color: var(--accent-color);
6960
6950
  opacity: 0.8;
6961
6951
  }
@@ -9017,3 +9007,5 @@ body {
9017
9007
  display: flex;
9018
9008
  gap: 1.25rem;
9019
9009
  }
9010
+
9011
+ /*# sourceMappingURL=style.css.map */