@docmd/themes 0.5.2 → 0.5.4

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.
@@ -12,53 +12,40 @@
12
12
  * --------------------------------------------------------------------
13
13
  */
14
14
 
15
- /*
15
+ /*
16
16
  * Sky Theme
17
17
  * Inspired by the clear blue sky
18
18
  * Features: Blue tones, clean lines, subtle gradients
19
19
  */
20
20
 
21
21
  :root {
22
- --sky-primary: #0097ff
22
+ --sky-primary: #0097ff;
23
23
  }
24
24
 
25
25
  :root[data-theme=light] {
26
- --font-family-sans: Inter, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
27
- --font-family-mono: 'JetBrains Mono', SFMono-Regular, Consolas, 'Liberation Mono', Menlo, monospace;
28
26
  --accent-color: #0097ff;
29
27
  --sky-primary: #0097ff;
30
- --sky-primary-light: #e5f4ff;
31
- --sky-primary-dark: #0078cc;
28
+ --sky-primary-light: #8acdff33;
29
+ --sky-primary-dark: #00497b;
32
30
  --sky-text: #1a1f36;
33
31
  --sky-text-light: #4a5568;
34
- --sky-text-lightest: #718096;
35
- --sky-background: #fff;
32
+ --sky-background: #ffffff;
36
33
  --sky-background-alt: #f9fafb;
37
34
  --sky-border: #e2e8f0;
38
- --sky-border-light: #edf2f7;
39
35
  --bg-color: var(--sky-background);
40
36
  --text-color: var(--sky-text);
37
+ --text-heading: var(--sky-text);
38
+ --text-muted: var(--sky-text-light);
41
39
  --sidebar-bg: #f7fafc;
42
40
  --sidebar-text: var(--sky-text-light);
43
- --sidebar-link-active-bg: #e5f4ff;
41
+ --sidebar-link-active-bg: var(--sky-primary-light);
44
42
  --sidebar-link-active-text: var(--sky-primary);
45
43
  --link-color: var(--sky-primary);
46
- --border-color: var(--sky-border);
47
- --code-bg: var(--sky-primary-light);
48
- --code-text: var(--sky-primary-dark);
44
+ --border-color: #6dabff57;
49
45
  --header-bg: var(--sky-background);
50
46
  --header-border: var(--sky-border);
51
- --shadow-sm: 0 1px 2px 0 #0000000d;
52
- --shadow-md: 0 4px 6px -1px #0000001a 0 2px 4px -1px #0000000f;
53
- --shadow-lg: 0 10px 15px -3px #0000001a 0 4px 6px -2px #0000000d;
54
- --image-border-color: var(--sky-border);
55
- --image-shadow: var(--shadow-md);
56
- --image-caption-bg: var(--sky-background-alt);
57
- --image-caption-text: var(--sky-text-light);
58
- --image-hover-transform: translateY(-2px);
59
- --image-hover-shadow: var(--shadow-lg);
60
- --image-border-radius: 8px;
61
- --image-transition: all .3s ease
47
+ --code-bg: var(--sky-primary-light);
48
+ --code-text: var(--sky-primary-dark);
62
49
  }
63
50
 
64
51
  :root[data-theme=dark] {
@@ -67,563 +54,197 @@
67
54
  --sky-primary-dark: #60a5fa;
68
55
  --sky-text: #f1f5f9;
69
56
  --sky-text-light: #cbd5e1;
70
- --sky-text-lightest: #94a3b8;
71
57
  --sky-background: #0f172a;
72
58
  --sky-background-alt: #1e293b;
73
59
  --sky-border: #334155;
74
- --sky-border-light: #1e293b;
60
+
75
61
  --bg-color: var(--sky-background);
76
62
  --text-color: var(--sky-text);
63
+ --text-heading: var(--sky-text);
64
+ --text-muted: var(--sky-text-light);
77
65
  --sidebar-bg: #0f172a;
78
66
  --sidebar-text: var(--sky-text-light);
79
67
  --sidebar-link-active-bg: #1e293b;
80
68
  --sidebar-link-active-text: var(--sky-primary);
81
69
  --link-color: var(--sky-primary);
82
70
  --border-color: var(--sky-border);
83
- --code-bg: var(--sky-primary-light);
84
- --code-text: var(--sky-text);
85
71
  --header-bg: var(--sky-background);
86
72
  --header-border: var(--sky-border);
87
- --shadow-sm: 0 1px 2px 0 #0000004d;
88
- --shadow-md: 0 4px 6px -1px #0000004d 0 2px 4px -1px #0003;
89
- --shadow-lg: 0 10px 15px -3px #0000004d 0 4px 6px -2px #0003;
90
- --image-border-color: var(--sky-border);
91
- --image-shadow: 0 4px 8px #00000080;
92
- --image-caption-bg: var(--sky-background-alt);
93
- --image-caption-text: var(--sky-text-light);
94
- --image-hover-transform: translateY(-2px);
95
- --image-hover-shadow: 0 6px 12px #000000b3;
96
- --image-border-radius: 8px;
97
- --image-transition: all .3s ease
98
- }
99
-
100
- body {
101
- font-feature-settings: salt, ss01, ss02;
102
- letter-spacing: -.01em
103
- }
104
-
105
- h1,
106
- h2,
107
- h3,
108
- h4,
109
- h5,
110
- h6 {
111
- font-weight: 600;
112
- line-height: 1.3;
113
- margin-top: 2em;
114
- margin-bottom: .5em;
115
- color: var(--sky-text)
116
- }
117
-
118
- .sidebar nav li a.active,
119
- .sidebar nav li a:hover {
120
- background-color: var(--sidebar-link-active-bg);
121
- color: var(--sidebar-link-active-text)
122
- }
123
-
124
- pre,
125
- table {
126
- margin: 1.5em 0;
127
- border-radius: 8px;
128
- box-shadow: var(--shadow-sm)
129
- }
130
-
131
- td,
132
- th {
133
- padding: .75rem 1rem
134
- }
135
-
136
- th,
137
- tr:hover {
138
- background-color: var(--sky-background-alt)
139
- }
140
-
141
- .callout,
142
- .steps {
143
- position: relative
144
- }
145
-
146
- .card,
147
- figure,
148
- table {
149
- overflow: hidden
150
- }
151
-
152
- .docmd-container,
153
- .sidebar,
154
- figure,
155
- pre,
156
- table {
157
- box-shadow: var(--shadow-sm)
158
- }
159
-
160
- .card .card-content>:last-child,
161
- figure img {
162
- margin-bottom: 0
163
- }
164
-
165
- .card .card-content>:first-child,
166
- h1 {
167
- margin-top: 0
168
- }
169
-
170
- h1 {
171
- font-size: 2.25rem;
172
- font-weight: 700
173
- }
174
-
175
- h2 {
176
- font-size: 1.75rem;
177
- border-bottom: 1px solid var(--sky-border-light);
178
- padding-bottom: .5rem
179
- }
180
-
181
- h3 {
182
- font-size: 1.5rem
183
- }
184
-
185
- h4 {
186
- font-size: 1.25rem
187
- }
188
-
189
- a {
190
- color: var(--link-color);
191
- text-decoration: none;
192
- transition: color .2s
193
- }
194
-
195
- a:hover {
196
- text-decoration: underline
197
- }
198
-
199
- p {
200
- margin: .5em 0;
201
- padding: .5em 0;
202
- line-height: 1.7
203
- }
204
-
205
- .sidebar nav li a {
206
- border-radius: 6px;
207
- margin-bottom: 2px;
208
- transition: .2s
209
- }
210
-
211
- .sidebar nav li a.active {
212
- font-weight: 500
213
- }
214
-
215
- .content-area {
216
- padding: 2.5rem 5%
217
- }
218
-
219
- pre {
220
- background-color: var(--code-bg);
221
- padding: 1.25em
222
- }
223
-
224
- code {
225
- font-size: .9em;
226
- border-radius: 4px;
227
- padding: .2em .4em
228
- }
229
-
230
- table {
231
- width: 100%;
232
- border-collapse: separate;
233
- border-spacing: 0
234
- }
235
-
236
- th {
237
- text-align: left;
238
- font-weight: 600
239
- }
240
-
241
- td {
242
- border-top: 1px solid var(--sky-border-light)
243
- }
244
-
245
- .docmd-container {
246
- padding: .5rem 1.5rem;
247
- margin: 1.75rem 0;
248
- border-radius: 10px;
249
- border: 1px solid var(--sky-border-light);
250
- background-color: var(--sky-background)
251
- }
252
-
253
- .callout,
254
- .card {
255
- background-color: var(--card-bg)
256
- }
257
-
258
- .callout {
259
- border: none;
260
- border-left: 5px solid
261
- }
262
-
263
- .callout-title {
264
- font-weight: 600;
265
- margin-bottom: .75em;
266
- display: flex;
267
- align-items: center
268
- }
269
-
270
- .callout-title::before {
271
- margin-right: .5rem;
272
- font-size: 1.1em
73
+ --code-bg: var(--sky-primary-light);
74
+ --code-text: var(--sky-text);
273
75
  }
274
76
 
275
- .callout-info {
276
- border-left-color: var(--sky-primary)
277
- }
77
+ /* Theme-specific overrides */
278
78
 
279
79
  .callout-info .callout-title::before {
280
- content: "ℹ️"
281
- }
282
-
283
- .callout-warning {
284
- border-left-color: #f59e0b
80
+ content: "ℹ️ ";
285
81
  }
286
82
 
287
83
  .callout-warning .callout-title::before {
288
- content: "⚠️"
289
- }
290
-
291
- .callout-success,
292
- .callout-tip {
293
- border-left-color: #10b981
84
+ content: "⚠️ ";
294
85
  }
295
86
 
296
87
  .callout-tip .callout-title::before {
297
- content: "💡"
298
- }
299
-
300
- .callout-danger {
301
- border-left-color: #ef4444
88
+ content: "💡 ";
302
89
  }
303
90
 
304
91
  .callout-danger .callout-title::before {
305
- content: "🚨"
92
+ content: "";
306
93
  }
307
94
 
308
95
  .callout-success .callout-title::before {
309
- content: "✅"
310
- }
311
-
312
- .card {
313
- border: 1px solid var(--sky-border);
314
- box-shadow: var(--text-color);
315
- transition: transform .2s, box-shadow .2s;
316
- display: flex;
317
- flex-direction: column
96
+ content: "✅ ";
318
97
  }
319
98
 
320
- .card:hover {
321
- transform: translateY(-2px);
322
- box-shadow: var(--shadow-lg)
323
- }
324
-
325
- .card .card-title {
326
- padding: .5rem 1.5rem 1rem;
327
- border-bottom: 1px solid var(--sky-border);
328
- font-weight: 600;
329
- margin-top: 0
330
- }
331
-
332
- .card .card-content {
333
- flex: 1;
334
- padding: .25rem
335
- }
336
-
337
- .steps {
338
- counter-reset: step-counter;
339
- border: none;
340
- background-color: transparent;
341
- box-shadow: none;
342
- padding: 0;
343
- margin-left: 1rem
344
- }
345
-
346
- .steps::before {
347
- content: '';
348
- position: absolute;
349
- top: 0;
350
- bottom: 0 !important;
351
- left: 1.5rem !important;
352
- width: 3px !important;
353
- background-color: var(--sky-border);
354
- transform: translateX(-50%);
355
- z-index: 0
356
- }
357
-
358
- .steps .step {
359
- position: relative;
360
- padding: .5rem 2.5em;
361
- border-radius: 10px;
362
- margin-bottom: 1em;
363
- display: block;
364
- background-color: var(--card-bg)
365
- }
366
-
367
- .steps .step:last-child {
368
- padding-bottom: 0
369
- }
370
-
371
- .steps h4,
372
- .steps ol li strong:first-child,
373
- .steps ol li:first-child {
374
- position: relative;
375
- counter-increment: step-counter;
376
- margin-bottom: 1rem;
377
- font-weight: 600;
378
- font-size: 1.1rem;
379
- display: block
380
- }
381
-
382
- .steps h4::before,
383
- .steps ol li::before {
384
- content: counter(list-counter) !important;
385
- position: absolute;
386
- left: -2.55rem;
387
- top: .5rem;
388
- width: 2rem;
389
- height: 2rem;
99
+ .content-area .button {
390
100
  background-color: var(--sky-primary);
391
- color: #fff !important;
392
- border-radius: 50%;
393
- display: flex;
394
- align-items: center;
395
- justify-content: center;
396
- font-size: 1rem !important;
397
- font-weight: 500 !important;
398
- z-index: 1
101
+ color: #ffffff;
102
+ border-radius: var(--radius-md);
399
103
  }
400
104
 
401
- .steps .step h4,
402
- .steps .step ol,
403
- .steps .step>div,
404
- .steps .step>p,
405
- .steps .step>pre,
406
- .steps ol,
407
- .steps ol li {
408
- display: block
105
+ .content-area .button:hover {
106
+ background-color: var(--sky-primary-dark);
409
107
  }
410
108
 
411
- .step-content,
412
- .step-content>div,
413
- .step-content>p,
414
- .step-content>pre {
415
- display: block;
416
- margin-top: .5rem;
417
- margin-bottom: 1rem
109
+ /* Polaroid effect */
110
+ figure.polaroid {
111
+ background: #ffffff;
112
+ padding: 10px 10px 30px;
113
+ box-shadow: var(--shadow-md);
114
+ border-radius: var(--radius-sm);
418
115
  }
419
116
 
420
- .steps ol+*,
421
- .steps pre {
422
- margin-top: 1rem
117
+ figure.polaroid figcaption {
118
+ background: #ffffff;
119
+ color: var(--sky-text);
120
+ font-size: 1.1rem;
121
+ font-style: italic;
423
122
  }
424
123
 
425
- .steps ol {
426
- list-style: none;
427
- padding-left: 0;
428
- margin-left: 0
124
+ [data-theme=dark] figure.polaroid,
125
+ [data-theme=dark] figure.polaroid figcaption {
126
+ background: #1e293b;
127
+ color: var(--sky-text);
429
128
  }
430
129
 
431
- .steps ol li {
432
- position: relative;
433
- margin-bottom: 1rem
130
+ .page-header,
131
+ .docmd-menubar {
132
+ background-color: var(--sidebar-bg);
133
+ border: 0;
434
134
  }
435
135
 
436
- .steps .step h4 {
437
- font-weight: 600;
438
- margin-bottom: 1rem
136
+ body.has-menubar-top:not(.no-header) {
137
+ --sticky-top-offset: calc(var(--header-h));
439
138
  }
440
139
 
441
- .steps .step ol {
442
- counter-reset: none;
443
- list-style: decimal;
444
- padding-left: 1.5rem;
445
- margin-top: .5rem
140
+ .sidebar {
141
+ border-right: 0;
142
+ padding-left: .25em;
446
143
  }
447
144
 
448
- .steps .step ol li {
449
- padding-left: 0;
450
- margin-bottom: .5rem;
451
- display: list-item
145
+ body {
146
+ background-color: var(--sidebar-bg);
452
147
  }
453
148
 
454
- .steps .step ol li::before {
455
- display: none
149
+ .content-theme-cover {
150
+ position: fixed;
151
+ overflow: scroll;
152
+ height: 100%;
153
+ border: 1px solid var(--sky-border);
154
+ margin-top: calc(var(--sticky-top-offset) + 5px);
155
+ border-radius: 1.5em 0 0 0;
156
+ background-color: var(--bg-color);
456
157
  }
457
158
 
458
- .steps pre {
459
- margin-bottom: 1rem
159
+ .version-dropdown-toggle {
160
+ width: 80%;
161
+ margin: 0 auto;
162
+ border-radius: 1rem;
163
+ background-color: var(--sky-primary-light);
460
164
  }
461
165
 
462
- .button,
463
- button {
464
- padding: .5rem 1rem;
465
- background-color: var(--sky-primary);
466
- color: #fff;
467
- border: none;
468
- border-radius: 6px;
469
- font-weight: 500;
470
- cursor: pointer;
471
- transition: background-color .2s
166
+ .sidebar nav li.nav-group {
167
+ background-color: var(--sky-primary-light);
168
+ border-radius: 10px;
472
169
  }
473
170
 
474
- .image-gallery figure,
475
- figure,
476
- img {
477
- transition: var(--image-transition)
171
+ .sidebar nav .submenu {
172
+ border: 0;
173
+ background-color: var(--sky-primary-light);
174
+ margin: 0 .5em .5em;
175
+ padding: .25em;
176
+ border-radius: 10px;
478
177
  }
479
178
 
480
- .button:hover,
481
- button:hover {
482
- background-color: var(--sky-primary-dark)
179
+ .sidebar nav li a,
180
+ .sidebar nav li .nav-label {
181
+ color: var(--sky-primary-dark);
483
182
  }
484
183
 
485
- .docmd-search-trigger,
486
- .theme-toggle-button {
487
- background-color: var(--sky-background-alt);
488
- border-color: var(--sky-border-light);
489
- border-radius: 6px;
490
- transition: .2s
184
+ .sidebar nav li {
185
+ margin: .25rem;
491
186
  }
492
187
 
493
- .docmd-search-trigger:hover,
188
+ .copy-code-button:hover,
189
+ .docmd-tabs-nav-item:hover,
190
+ .sidebar nav li a.active,
191
+ .sidebar nav li a:hover,
494
192
  .theme-toggle-button:hover {
495
- background-color: var(--sky-primary-light)
496
- }
497
-
498
- img {
499
- border-radius: var(--image-border-radius)
500
- }
501
-
502
- img.with-border {
503
- border: 1px solid var(--image-border-color);
504
- padding: 8px;
505
- background-color: var(--bg-color)
506
- }
507
-
508
- img.with-shadow {
509
- box-shadow: var(--image-shadow)
510
- }
511
-
512
- img.with-shadow:hover {
513
- box-shadow: var(--image-hover-shadow)
514
- }
515
-
516
- figure {
517
- border-radius: var(--image-border-radius)
518
- }
519
-
520
- figure:hover {
521
- box-shadow: var(--shadow-md)
522
- }
523
-
524
- figure img {
525
- border-radius: var(--image-border-radius) var(--image-border-radius) 0 0
526
- }
527
-
528
- figcaption {
529
- background-color: var(--image-caption-bg);
530
- color: var(--image-caption-text);
531
- padding: .75rem 1rem;
532
- font-size: .9rem;
533
- font-weight: 500
534
- }
535
-
536
- .image-gallery {
537
- display: grid;
538
- grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
539
- gap: 1.5rem;
540
- margin: 2rem 0
541
- }
542
-
543
- .image-gallery figure {
544
- height: 100%;
545
- display: flex;
546
- flex-direction: column;
547
- margin: 0
193
+ background-color: var(--sky-primary-light);
548
194
  }
549
195
 
550
- .image-gallery figure:hover {
551
- transform: var(--image-hover-transform)
196
+ .sidebar nav li a.active {
197
+ color: var(--sky-primary-dark);
552
198
  }
553
199
 
554
- .image-gallery img {
555
- height: 200px;
556
- width: 100%;
557
- object-fit: cover;
558
- margin: 0
200
+ .toc-sidebar {
201
+ top: 1rem;
559
202
  }
560
203
 
561
- .image-gallery figcaption {
562
- flex: 1;
563
- display: flex;
564
- align-items: center;
565
- justify-content: center;
566
- text-align: center
204
+ .version-dropdown-menu {
205
+ width: 80%;
206
+ margin: 0 auto;
567
207
  }
568
208
 
569
- .image-gallery.zoom img {
570
- transition: transform .5s
209
+ .version-dropdown-toggle:hover {
210
+ border-color: var(--sky-primary);
571
211
  }
572
212
 
573
- .image-gallery.zoom figure:hover img {
574
- transform: scale(1.05)
213
+ .footer-complete {
214
+ background-color: var(--bg-color);
215
+ padding: 0;
216
+ margin: 0 var(--space-8);
217
+ padding: var(--space-12) 0 var(--space-6);
575
218
  }
576
219
 
577
- img.lightbox {
578
- cursor: zoom-in
220
+ .page-footer-actions {
221
+ border-top: 0;
579
222
  }
580
223
 
581
- img.framed {
582
- border: 8px solid #fff;
583
- box-shadow: 0 0 0 1px var(--image-border-color), var(--image-shadow);
584
- box-sizing: border-box
224
+ .footer-complete-bottom {
225
+ border-top: 0;
585
226
  }
586
227
 
587
- figure.polaroid {
588
- background: #fff;
589
- padding: 10px 10px 30px;
590
- box-shadow: var(--shadow-md)
228
+ .docmd-kbd {
229
+ background-color: var(--sky-primary-light);
230
+ color: var(--sky-primary);
591
231
  }
592
232
 
593
- figure.polaroid img {
594
- border-radius: 0;
595
- box-shadow: none
233
+ .docmd-search-trigger .search-label,
234
+ .docmd-options-menu .lucide-icon {
235
+ color: var(--sky-primary-dark);
596
236
  }
597
237
 
598
- figure.polaroid figcaption {
599
- background: #fff;
600
- color: var(--sky-text);
601
- font-family: Caveat, cursive, var(--font-family-sans);
602
- font-size: 1.1rem
238
+ .docmd-options-menu .sponsor-link-button:hover,
239
+ .docmd-options-menu .sponsor-link-button:hover svg,
240
+ .docmd-options-menu button:hover:not(.docmd-search-trigger) {
241
+ background-color: var(--sky-primary);
242
+ color: var(--sky-primary-dark);
243
+ border: initial;
244
+ transition: 0.2s;
603
245
  }
604
246
 
605
- @media (max-width:768px) {
606
- .content-area {
607
- padding: 1.5rem 1rem
608
- }
609
-
610
- h1 {
611
- font-size: 1.75rem
612
- }
613
-
614
- h2 {
615
- font-size: 1.5rem
616
- }
617
-
618
- h3 {
619
- font-size: 1.25rem
620
- }
621
-
622
- .image-gallery {
623
- grid-template-columns: repeat(auto-fill, minmax(200px, 1fr))
624
- }
625
-
626
- .image-gallery img {
627
- height: 150px
628
- }
247
+ .docmd-options-menu .theme-toggle-button,
248
+ .docmd-options-menu .sponsor-link-button {
249
+ border-radius: 50%;
629
250
  }