boreal-ui 0.0.10 → 0.0.12
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.
- package/dist/core/CheveronDownIcon-B2codmaq.cjs +26 -0
- package/dist/core/CheveronDownIcon-B2codmaq.cjs.map +1 -0
- package/dist/core/CheveronDownIcon-Cn9jj-ku.js +27 -0
- package/dist/core/CheveronDownIcon-Cn9jj-ku.js.map +1 -0
- package/dist/core/{Footer-bKgKgU6L.js → Footer-7ixaMvFc.js} +2 -2
- package/dist/core/{Footer-bKgKgU6L.js.map → Footer-7ixaMvFc.js.map} +1 -1
- package/dist/core/{Footer-B4Owy88y.cjs → Footer-Dc_CuIC1.cjs} +2 -2
- package/dist/core/{Footer-B4Owy88y.cjs.map → Footer-Dc_CuIC1.cjs.map} +1 -1
- package/dist/core/Footer.cjs.js +1 -1
- package/dist/core/Footer.js +1 -1
- package/dist/core/{Select-9F6p9ghR.cjs → Select-CitauzQm.cjs} +3 -24
- package/dist/core/Select-CitauzQm.cjs.map +1 -0
- package/dist/core/{Select-C4a_4B87.js → Select-_12yQ-yj.js} +3 -24
- package/dist/core/Select-_12yQ-yj.js.map +1 -0
- package/dist/core/Select.cjs.js +1 -1
- package/dist/core/Select.js +1 -1
- package/dist/core/Sidebar-CqTJJULG.cjs +216 -0
- package/dist/core/Sidebar-CqTJJULG.cjs.map +1 -0
- package/dist/core/Sidebar-z0mG5nn_.js +217 -0
- package/dist/core/Sidebar-z0mG5nn_.js.map +1 -0
- package/dist/core/Sidebar.cjs.js +4 -0
- package/dist/core/Sidebar.cjs.js.map +1 -0
- package/dist/core/Sidebar.js +5 -0
- package/dist/core/Sidebar.js.map +1 -0
- package/dist/core/index.cjs.js +4 -2
- package/dist/core/index.cjs.js.map +1 -1
- package/dist/core/index.js +4 -2
- package/dist/core/index.js.map +1 -1
- package/dist/core/style.css +713 -0
- package/dist/next/CheveronDownIcon-Cn9jj-ku.js +27 -0
- package/dist/next/CheveronDownIcon-Cn9jj-ku.js.map +1 -0
- package/dist/next/CheveronDownIcon-CyoOZUNY.cjs +26 -0
- package/dist/next/CheveronDownIcon-CyoOZUNY.cjs.map +1 -0
- package/dist/next/{Footer-D2veQTa-.cjs → Footer-J0Tb7-n4.cjs} +2 -2
- package/dist/next/{Footer-D2veQTa-.cjs.map → Footer-J0Tb7-n4.cjs.map} +1 -1
- package/dist/next/{Footer-CQAWg2tl.js → Footer-bb_8EH_R.js} +2 -2
- package/dist/next/{Footer-CQAWg2tl.js.map → Footer-bb_8EH_R.js.map} +1 -1
- package/dist/next/Footer.cjs.js +1 -1
- package/dist/next/Footer.js +1 -1
- package/dist/next/NavBar-CRbRBzGq.js +163 -0
- package/dist/next/NavBar-CRbRBzGq.js.map +1 -0
- package/dist/next/NavBar-JPkuek76.cjs +162 -0
- package/dist/next/NavBar-JPkuek76.cjs.map +1 -0
- package/dist/next/NavBar.cjs.js +1 -1
- package/dist/next/NavBar.js +1 -1
- package/dist/next/{Select-_f1aZuKO.cjs → Select-Bln5-seQ.cjs} +3 -24
- package/dist/next/Select-Bln5-seQ.cjs.map +1 -0
- package/dist/next/{Select-DwWTQcCU.js → Select-CdWyrGrV.js} +3 -24
- package/dist/next/Select-CdWyrGrV.js.map +1 -0
- package/dist/next/Select.cjs.js +1 -1
- package/dist/next/Select.js +1 -1
- package/dist/next/Sidebar-DBmaTOMW.js +285 -0
- package/dist/next/Sidebar-DBmaTOMW.js.map +1 -0
- package/dist/next/Sidebar-Rl3o8_ya.cjs +284 -0
- package/dist/next/Sidebar-Rl3o8_ya.cjs.map +1 -0
- package/dist/next/Sidebar.cjs.js +4 -0
- package/dist/next/Sidebar.cjs.js.map +1 -0
- package/dist/next/Sidebar.js +5 -0
- package/dist/next/Sidebar.js.map +1 -0
- package/dist/next/index.cjs.js +5 -3
- package/dist/next/index.cjs.js.map +1 -1
- package/dist/next/index.js +6 -4
- package/dist/next/index.js.map +1 -1
- package/dist/next/{NavBar-DzRWv8W0.js → navigation-DTwYCgCL.js} +4 -160
- package/dist/next/navigation-DTwYCgCL.js.map +1 -0
- package/dist/next/{NavBar-CZtNDAdX.cjs → navigation-m012syo9.cjs} +2 -158
- package/dist/next/navigation-m012syo9.cjs.map +1 -0
- package/dist/next/style.css +696 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/components/Sidebar/Sidebar.types.d.ts +112 -0
- package/dist/types/components/Sidebar/Sidebar.types.d.ts.map +1 -0
- package/dist/types/components/Sidebar/SidebarBase.d.ts +5 -0
- package/dist/types/components/Sidebar/SidebarBase.d.ts.map +1 -0
- package/dist/types/components/Sidebar/core/Sidebar.d.ts +6 -0
- package/dist/types/components/Sidebar/core/Sidebar.d.ts.map +1 -0
- package/dist/types/components/Sidebar/next/Sidebar.d.ts +5 -0
- package/dist/types/components/Sidebar/next/Sidebar.d.ts.map +1 -0
- package/dist/types/index.core.d.ts +1 -0
- package/dist/types/index.core.d.ts.map +1 -1
- package/dist/types/index.next.d.ts +1 -0
- package/dist/types/index.next.d.ts.map +1 -1
- package/package.json +2 -2
- package/dist/core/Select-9F6p9ghR.cjs.map +0 -1
- package/dist/core/Select-C4a_4B87.js.map +0 -1
- package/dist/next/NavBar-CZtNDAdX.cjs.map +0 -1
- package/dist/next/NavBar-DzRWv8W0.js.map +0 -1
- package/dist/next/Select-DwWTQcCU.js.map +0 -1
- package/dist/next/Select-_f1aZuKO.cjs.map +0 -1
package/dist/core/style.css
CHANGED
|
@@ -21196,6 +21196,719 @@ a:hover {
|
|
|
21196
21196
|
border: 0;
|
|
21197
21197
|
}
|
|
21198
21198
|
|
|
21199
|
+
.sidebar {
|
|
21200
|
+
position: relative;
|
|
21201
|
+
width: 240px;
|
|
21202
|
+
height: 100vh;
|
|
21203
|
+
background-color: var(--background-color-light);
|
|
21204
|
+
border-right: 1px solid var(--background-color-lighter);
|
|
21205
|
+
position: sticky;
|
|
21206
|
+
top: 0;
|
|
21207
|
+
overflow-y: auto;
|
|
21208
|
+
font-family: var(--font-family-primary);
|
|
21209
|
+
}
|
|
21210
|
+
.sidebar_round-None {
|
|
21211
|
+
border-radius: 0;
|
|
21212
|
+
}
|
|
21213
|
+
.sidebar_round-Small {
|
|
21214
|
+
border-radius: 5px;
|
|
21215
|
+
}
|
|
21216
|
+
.sidebar_round-Medium {
|
|
21217
|
+
border-radius: 10px;
|
|
21218
|
+
}
|
|
21219
|
+
.sidebar_round-Large {
|
|
21220
|
+
border-radius: 20px;
|
|
21221
|
+
}
|
|
21222
|
+
.sidebar_round-Full {
|
|
21223
|
+
border-radius: 50%;
|
|
21224
|
+
}
|
|
21225
|
+
.sidebar_shadow-None {
|
|
21226
|
+
box-shadow: 0;
|
|
21227
|
+
}
|
|
21228
|
+
.sidebar_shadow-Light {
|
|
21229
|
+
box-shadow: 0px 2px 4px rgba(46, 49, 49, 0.1);
|
|
21230
|
+
}
|
|
21231
|
+
.sidebar_shadow-Medium {
|
|
21232
|
+
box-shadow: 0px 4px 8px rgba(86, 101, 116, 0.2);
|
|
21233
|
+
}
|
|
21234
|
+
.sidebar_shadow-Strong {
|
|
21235
|
+
box-shadow: 0px 6px 12px rgba(52, 73, 94, 0.4);
|
|
21236
|
+
}
|
|
21237
|
+
.sidebar_shadow-Intense {
|
|
21238
|
+
box-shadow: 0px 6px 12px rgba(52, 73, 94, 0.6);
|
|
21239
|
+
}
|
|
21240
|
+
.sidebar_primary .sidebar_active {
|
|
21241
|
+
background-color: var(--primary-color);
|
|
21242
|
+
}
|
|
21243
|
+
.sidebar_primary.sidebar_outline .sidebar_active {
|
|
21244
|
+
background-color: transparent;
|
|
21245
|
+
border: 2px solid var(--primary-color);
|
|
21246
|
+
}
|
|
21247
|
+
.sidebar_clear.sidebar_primary .sidebar_active {
|
|
21248
|
+
border: 2px solid var(--primary-color);
|
|
21249
|
+
}
|
|
21250
|
+
.sidebar_secondary .sidebar_active {
|
|
21251
|
+
background-color: var(--secondary-color);
|
|
21252
|
+
}
|
|
21253
|
+
.sidebar_secondary.sidebar_outline .sidebar_active {
|
|
21254
|
+
background-color: transparent;
|
|
21255
|
+
border: 2px solid var(--secondary-color);
|
|
21256
|
+
}
|
|
21257
|
+
.sidebar_clear.sidebar_secondary .sidebar_active {
|
|
21258
|
+
border: 2px solid var(--secondary-color);
|
|
21259
|
+
}
|
|
21260
|
+
.sidebar_tertiary .sidebar_active {
|
|
21261
|
+
background-color: var(--tertiary-color);
|
|
21262
|
+
}
|
|
21263
|
+
.sidebar_tertiary.sidebar_outline .sidebar_active {
|
|
21264
|
+
background-color: transparent;
|
|
21265
|
+
border: 2px solid var(--tertiary-color);
|
|
21266
|
+
}
|
|
21267
|
+
.sidebar_clear.sidebar_tertiary .sidebar_active {
|
|
21268
|
+
border: 2px solid var(--tertiary-color);
|
|
21269
|
+
}
|
|
21270
|
+
.sidebar_quaternary .sidebar_active {
|
|
21271
|
+
background-color: var(--quaternary-color);
|
|
21272
|
+
}
|
|
21273
|
+
.sidebar_quaternary.sidebar_outline .sidebar_active {
|
|
21274
|
+
background-color: transparent;
|
|
21275
|
+
border: 2px solid var(--quaternary-color);
|
|
21276
|
+
}
|
|
21277
|
+
.sidebar_clear.sidebar_quaternary .sidebar_active {
|
|
21278
|
+
border: 2px solid var(--quaternary-color);
|
|
21279
|
+
}
|
|
21280
|
+
.sidebar_clear .sidebar_active {
|
|
21281
|
+
background-color: transparent;
|
|
21282
|
+
color: var(--text-color-primary);
|
|
21283
|
+
}
|
|
21284
|
+
.sidebar_clear.sidebar_outline .sidebar_active {
|
|
21285
|
+
background-color: transparent;
|
|
21286
|
+
color: var(--text-color-primary);
|
|
21287
|
+
border: 2px solid var(--text-color-primary);
|
|
21288
|
+
}
|
|
21289
|
+
.sidebar_clear.sidebar_clear .sidebar_active {
|
|
21290
|
+
border: 2px solid var(--text-color-primary);
|
|
21291
|
+
}
|
|
21292
|
+
.sidebar_success .sidebar_active {
|
|
21293
|
+
background-color: #51c703;
|
|
21294
|
+
}
|
|
21295
|
+
.sidebar_success .sidebar_active:hover {
|
|
21296
|
+
background-color: rgb(60.5495049505, 148.7574257426, 2.2425742574);
|
|
21297
|
+
}
|
|
21298
|
+
.sidebar_success.sidebar_outline .sidebar_active {
|
|
21299
|
+
border: 2px solid #51c703;
|
|
21300
|
+
background-color: transparent;
|
|
21301
|
+
}
|
|
21302
|
+
.sidebar_success.sidebar_outline .sidebar_active:hover {
|
|
21303
|
+
background-color: rgb(60.5495049505, 148.7574257426, 2.2425742574);
|
|
21304
|
+
}
|
|
21305
|
+
.sidebar_error .sidebar_active {
|
|
21306
|
+
background-color: #f83838;
|
|
21307
|
+
}
|
|
21308
|
+
.sidebar_error .sidebar_active:hover {
|
|
21309
|
+
background-color: rgb(244.4029126214, 8.5970873786, 8.5970873786);
|
|
21310
|
+
}
|
|
21311
|
+
.sidebar_error.sidebar_outline .sidebar_active {
|
|
21312
|
+
border: 2px solid #f83838;
|
|
21313
|
+
background-color: transparent;
|
|
21314
|
+
}
|
|
21315
|
+
.sidebar_error.sidebar_outline .sidebar_active:hover {
|
|
21316
|
+
background-color: rgb(244.4029126214, 8.5970873786, 8.5970873786);
|
|
21317
|
+
}
|
|
21318
|
+
.sidebar_warning .sidebar_active {
|
|
21319
|
+
background-color: #fca505;
|
|
21320
|
+
}
|
|
21321
|
+
.sidebar_warning .sidebar_active:hover {
|
|
21322
|
+
background-color: rgb(203.557312253, 132.7193675889, 2.442687747);
|
|
21323
|
+
}
|
|
21324
|
+
.sidebar_warning.sidebar_outline .sidebar_active {
|
|
21325
|
+
border: 2px solid #fca505;
|
|
21326
|
+
background-color: transparent;
|
|
21327
|
+
}
|
|
21328
|
+
.sidebar_warning.sidebar_outline .sidebar_active:hover {
|
|
21329
|
+
background-color: rgb(203.557312253, 132.7193675889, 2.442687747);
|
|
21330
|
+
}
|
|
21331
|
+
|
|
21332
|
+
.sidebar_nav {
|
|
21333
|
+
display: flex;
|
|
21334
|
+
flex-direction: column;
|
|
21335
|
+
}
|
|
21336
|
+
|
|
21337
|
+
.sidebar_list {
|
|
21338
|
+
list-style: none;
|
|
21339
|
+
padding: 0;
|
|
21340
|
+
margin: 0;
|
|
21341
|
+
}
|
|
21342
|
+
|
|
21343
|
+
.sidebar_link {
|
|
21344
|
+
display: flex;
|
|
21345
|
+
justify-content: space-between;
|
|
21346
|
+
align-items: center;
|
|
21347
|
+
width: 100%;
|
|
21348
|
+
padding: 0.5rem 0.75rem;
|
|
21349
|
+
border-radius: var(--border-radius-sm);
|
|
21350
|
+
color: var(--text-color-secondary);
|
|
21351
|
+
text-decoration: none;
|
|
21352
|
+
background: none;
|
|
21353
|
+
border: none;
|
|
21354
|
+
cursor: pointer;
|
|
21355
|
+
transition: 0.3s ease-in-out;
|
|
21356
|
+
}
|
|
21357
|
+
.sidebar_link:hover {
|
|
21358
|
+
text-decoration: none;
|
|
21359
|
+
background-color: var(--background-color-dark);
|
|
21360
|
+
color: var(--text-color-primary);
|
|
21361
|
+
letter-spacing: 0.05em;
|
|
21362
|
+
}
|
|
21363
|
+
.sidebar_link:focus {
|
|
21364
|
+
outline: 2px solid var(--text-color-primary);
|
|
21365
|
+
outline-offset: 2px;
|
|
21366
|
+
}
|
|
21367
|
+
|
|
21368
|
+
.sidebar_active {
|
|
21369
|
+
font-weight: bolder;
|
|
21370
|
+
letter-spacing: 0.1em;
|
|
21371
|
+
}
|
|
21372
|
+
|
|
21373
|
+
.sidebar_child-link {
|
|
21374
|
+
font-size: 0.9rem;
|
|
21375
|
+
}
|
|
21376
|
+
|
|
21377
|
+
.sidebar_chevron {
|
|
21378
|
+
transition: transform 0.2s ease;
|
|
21379
|
+
}
|
|
21380
|
+
|
|
21381
|
+
.icon {
|
|
21382
|
+
display: inline-flex;
|
|
21383
|
+
align-items: center;
|
|
21384
|
+
margin-right: 2px;
|
|
21385
|
+
}
|
|
21386
|
+
.icon svg {
|
|
21387
|
+
width: 1em;
|
|
21388
|
+
height: 1em;
|
|
21389
|
+
}
|
|
21390
|
+
|
|
21391
|
+
.sidebar_chevronOpen {
|
|
21392
|
+
transform: rotate(180deg);
|
|
21393
|
+
}
|
|
21394
|
+
|
|
21395
|
+
.sidebar_submenu {
|
|
21396
|
+
max-height: 0;
|
|
21397
|
+
overflow: hidden;
|
|
21398
|
+
transition: max-height 0.25s ease;
|
|
21399
|
+
}
|
|
21400
|
+
|
|
21401
|
+
.sidebar_child-list {
|
|
21402
|
+
border-left: 3px solid var(--background-color-darker);
|
|
21403
|
+
margin: 0.25rem 0;
|
|
21404
|
+
}
|
|
21405
|
+
|
|
21406
|
+
.sidebar_footer {
|
|
21407
|
+
position: absolute;
|
|
21408
|
+
bottom: 0px;
|
|
21409
|
+
margin-top: auto;
|
|
21410
|
+
width: 100%;
|
|
21411
|
+
padding: 1rem;
|
|
21412
|
+
border-top: 1px solid var(--background-color-darker);
|
|
21413
|
+
display: flex;
|
|
21414
|
+
flex-direction: column;
|
|
21415
|
+
gap: 0.5rem;
|
|
21416
|
+
}
|
|
21417
|
+
|
|
21418
|
+
.sidebar_footer-link {
|
|
21419
|
+
font-size: 0.85rem;
|
|
21420
|
+
text-decoration: none;
|
|
21421
|
+
}
|
|
21422
|
+
.sidebar_footer-link:hover {
|
|
21423
|
+
color: var(--text-color-primary);
|
|
21424
|
+
}
|
|
21425
|
+
.sidebar_footer-link:focus {
|
|
21426
|
+
outline: 2px solid var(--text-color-primary);
|
|
21427
|
+
outline-offset: 2px;
|
|
21428
|
+
}
|
|
21429
|
+
|
|
21430
|
+
.sidebar_footer-version {
|
|
21431
|
+
font-size: 0.75rem;
|
|
21432
|
+
opacity: 0.7;
|
|
21433
|
+
margin-top: 0.5rem;
|
|
21434
|
+
}
|
|
21435
|
+
/**
|
|
21436
|
+
* ---------------------------------------------------------------------
|
|
21437
|
+
* theme.scss
|
|
21438
|
+
* ---------------------------------------------------------------------
|
|
21439
|
+
* Global design tokens and theme configuration for the Boreal UI system.
|
|
21440
|
+
* This file defines SCSS variables, maps, and constants for:
|
|
21441
|
+
* - Colors (brand, background, feedback, text)
|
|
21442
|
+
* - Fonts (families, sizes, weights)
|
|
21443
|
+
* - Spacing
|
|
21444
|
+
* - Border radii
|
|
21445
|
+
* - Shadows
|
|
21446
|
+
* - Transitions
|
|
21447
|
+
* - Z-index layers
|
|
21448
|
+
* - Thematic color maps
|
|
21449
|
+
* - UI states (success, error, warning)
|
|
21450
|
+
* - Rounding and shadow presets
|
|
21451
|
+
*
|
|
21452
|
+
* All variables support the `!default` flag to allow overrides via user-defined themes.
|
|
21453
|
+
* ---------------------------------------------------------------------
|
|
21454
|
+
*
|
|
21455
|
+
* == Color Palette ==
|
|
21456
|
+
* $primary-color – Brand primary color
|
|
21457
|
+
* $secondary-color – Secondary accent color
|
|
21458
|
+
* $tertiary-color – Alternate accent color
|
|
21459
|
+
* $quaternary-color – Alternate accent color
|
|
21460
|
+
* $background-color – Main background color (dark)
|
|
21461
|
+
* $background-color-surface – Surface layer background (cards, modals)
|
|
21462
|
+
* $error-color, $success-color, $warning-color – Feedback states
|
|
21463
|
+
* $link-color – Link default color
|
|
21464
|
+
* $link-hover-color – Link hover state
|
|
21465
|
+
* $text-color, $text-color-light, $text-color-primary, $text-color-secondary – Text coloring
|
|
21466
|
+
*
|
|
21467
|
+
* == Typography ==
|
|
21468
|
+
* $font-family-primary / secondary – Primary typefaces
|
|
21469
|
+
* $font-size-xxs to $font-size-xxl – Font size scale
|
|
21470
|
+
* $font-weight-light to bolder – Font weights
|
|
21471
|
+
*
|
|
21472
|
+
* == Spacing ==
|
|
21473
|
+
* $spacing-xxs to $spacing-xl – Margin/padding utility scale
|
|
21474
|
+
*
|
|
21475
|
+
* == Border Radius ==
|
|
21476
|
+
* $border-radius-xs to full – Border rounding presets
|
|
21477
|
+
*
|
|
21478
|
+
* == Shadows ==
|
|
21479
|
+
* $box-shadow-light to intense – Shadow elevation levels
|
|
21480
|
+
* $inverted-shadows – Shadows used on dark surfaces (e.g. modals)
|
|
21481
|
+
*
|
|
21482
|
+
* == Transitions ==
|
|
21483
|
+
* $transition-fast / default / slow – Standard easing transitions
|
|
21484
|
+
*
|
|
21485
|
+
* == Z-Index Layers ==
|
|
21486
|
+
* $z-index-drawer – For slide-out panels
|
|
21487
|
+
* $z-index-modal – For modals and overlays
|
|
21488
|
+
* $z-index-tooltip – Highest layer for tooltips and floating labels
|
|
21489
|
+
*
|
|
21490
|
+
* == Theme Map ==
|
|
21491
|
+
* $themes: map of theme names (e.g. "primary", "secondary") to their visual styles
|
|
21492
|
+
* - Each theme includes: bg, hover, text, border, text-hover
|
|
21493
|
+
*
|
|
21494
|
+
* == State Map ==
|
|
21495
|
+
* $states: visual styles for UI feedback states (success, error, warning)
|
|
21496
|
+
*
|
|
21497
|
+
* == Rounding / Shadow Maps ==
|
|
21498
|
+
* $rounding: key-value pairs for component rounding levels
|
|
21499
|
+
* $shadow: key-value pairs for shadow levels
|
|
21500
|
+
*/
|
|
21501
|
+
/**
|
|
21502
|
+
* ---------------------------------------------------------------------
|
|
21503
|
+
* globals.scss
|
|
21504
|
+
* ---------------------------------------------------------------------
|
|
21505
|
+
* Global style definitions and base theme setup for Boreal UI.
|
|
21506
|
+
* This file is responsible for setting:
|
|
21507
|
+
*
|
|
21508
|
+
* 1. CSS Variables (`:root`) — Derived from SCSS theme tokens
|
|
21509
|
+
* - Automatically syncs SCSS color and font variables to global CSS variables
|
|
21510
|
+
* - Enables theming and dynamic runtime overrides
|
|
21511
|
+
*
|
|
21512
|
+
* 2. Global Element Styles
|
|
21513
|
+
* - `body`, headings (`h1–h6`), paragraphs, links, and layout defaults
|
|
21514
|
+
* - Applies font, color, spacing, and background rules using theme tokens
|
|
21515
|
+
*
|
|
21516
|
+
* 3. Scrollbar Styling
|
|
21517
|
+
* - Thin scrollbar with custom thumb and track colors
|
|
21518
|
+
* - Supports hiding scrollbars with `.hideScrollbar` utility
|
|
21519
|
+
*
|
|
21520
|
+
* 4. Focus Outlines
|
|
21521
|
+
* - Custom `:focus` styles using accessible high-contrast outlines
|
|
21522
|
+
*
|
|
21523
|
+
* 5. Utility Classes
|
|
21524
|
+
* - `.noScroll`: disables scroll overflow
|
|
21525
|
+
* - `.errorMessage`: standardized error message styling
|
|
21526
|
+
* - `.loadingContainer`: centered layout for loading views
|
|
21527
|
+
* - `.sr_only` and `:global(.sr_only)`: accessibility class for screen-reader-only content
|
|
21528
|
+
*
|
|
21529
|
+
* 6. Mixin: `visually-hidden`
|
|
21530
|
+
* - Reusable mixin for accessibility-hidden content
|
|
21531
|
+
* - Applied via `.sr_only` and `:global(.sr_only)`
|
|
21532
|
+
*
|
|
21533
|
+
* Dependencies:
|
|
21534
|
+
* - Resets: `modern-css-reset`
|
|
21535
|
+
* - SCSS Modules: `theme`, `animations`, `breakpoints`
|
|
21536
|
+
* - Sass Color Utilities: `sass:color`
|
|
21537
|
+
*
|
|
21538
|
+
* Note:
|
|
21539
|
+
* All transitions use the theme-defined `$transition-default` for consistency.
|
|
21540
|
+
* CSS variables allow dynamic switching between light/dark/custom themes.
|
|
21541
|
+
*/
|
|
21542
|
+
/**
|
|
21543
|
+
* -----------------------------------------------------
|
|
21544
|
+
* _animations.scss
|
|
21545
|
+
* -----------------------------------------------------
|
|
21546
|
+
* This file contains reusable keyframe animations
|
|
21547
|
+
* used across the component library for transitions,
|
|
21548
|
+
* loaders, and visual enhancements.
|
|
21549
|
+
*
|
|
21550
|
+
* List of Animations:
|
|
21551
|
+
*
|
|
21552
|
+
* 1. fade-in
|
|
21553
|
+
* - Smoothly fades in an element by transitioning opacity from 0 to 1.
|
|
21554
|
+
*
|
|
21555
|
+
* 2. slide-up
|
|
21556
|
+
* - Slides an element upward into view from below while fading in.
|
|
21557
|
+
*
|
|
21558
|
+
* 3. spin-3d
|
|
21559
|
+
* - Rotates an element in 3D space along both X and Y axes (360°).
|
|
21560
|
+
*
|
|
21561
|
+
* 4. spin
|
|
21562
|
+
* - Continuously rotates an element clockwise in 2D space.
|
|
21563
|
+
*
|
|
21564
|
+
* 5. pulse
|
|
21565
|
+
* - Gently scales an element up and down to create a pulsing effect.
|
|
21566
|
+
*
|
|
21567
|
+
* 6. fade-in-up
|
|
21568
|
+
* - Combines a fade-in with a slight upward motion (used for tooltips, popups).
|
|
21569
|
+
*
|
|
21570
|
+
* 7. progress-grow
|
|
21571
|
+
* - Expands the width of a progress bar from 0% to 100%.
|
|
21572
|
+
*
|
|
21573
|
+
* 8. indeterminate-move
|
|
21574
|
+
* - Moves an element from left to right in a loop, used in indeterminate loaders.
|
|
21575
|
+
*
|
|
21576
|
+
* 9. skeleton-loading
|
|
21577
|
+
* - Creates a sweeping shimmer effect for skeleton loaders.
|
|
21578
|
+
*/
|
|
21579
|
+
@keyframes fade-in {
|
|
21580
|
+
from {
|
|
21581
|
+
opacity: 0;
|
|
21582
|
+
}
|
|
21583
|
+
to {
|
|
21584
|
+
opacity: 1;
|
|
21585
|
+
}
|
|
21586
|
+
}
|
|
21587
|
+
@keyframes slide-up {
|
|
21588
|
+
from {
|
|
21589
|
+
transform: translateY(100%);
|
|
21590
|
+
opacity: 0;
|
|
21591
|
+
}
|
|
21592
|
+
to {
|
|
21593
|
+
transform: translateY(0);
|
|
21594
|
+
opacity: 1;
|
|
21595
|
+
}
|
|
21596
|
+
}
|
|
21597
|
+
@keyframes spin-3d {
|
|
21598
|
+
0% {
|
|
21599
|
+
transform: rotateX(0deg) rotateY(0deg);
|
|
21600
|
+
}
|
|
21601
|
+
100% {
|
|
21602
|
+
transform: rotateX(360deg) rotateY(360deg);
|
|
21603
|
+
}
|
|
21604
|
+
}
|
|
21605
|
+
@keyframes spin {
|
|
21606
|
+
0% {
|
|
21607
|
+
transform: rotate(0deg);
|
|
21608
|
+
}
|
|
21609
|
+
100% {
|
|
21610
|
+
transform: rotate(360deg);
|
|
21611
|
+
}
|
|
21612
|
+
}
|
|
21613
|
+
@keyframes pulse {
|
|
21614
|
+
0% {
|
|
21615
|
+
transform: scale(1);
|
|
21616
|
+
}
|
|
21617
|
+
50% {
|
|
21618
|
+
transform: scale(1.1);
|
|
21619
|
+
}
|
|
21620
|
+
100% {
|
|
21621
|
+
transform: scale(1);
|
|
21622
|
+
}
|
|
21623
|
+
}
|
|
21624
|
+
@keyframes fade-in-up {
|
|
21625
|
+
from {
|
|
21626
|
+
opacity: 0;
|
|
21627
|
+
transform: translateY(-5px);
|
|
21628
|
+
}
|
|
21629
|
+
to {
|
|
21630
|
+
opacity: 1;
|
|
21631
|
+
transform: translateY(0);
|
|
21632
|
+
}
|
|
21633
|
+
}
|
|
21634
|
+
@keyframes progress-grow {
|
|
21635
|
+
from {
|
|
21636
|
+
width: 0;
|
|
21637
|
+
}
|
|
21638
|
+
to {
|
|
21639
|
+
width: 100%;
|
|
21640
|
+
}
|
|
21641
|
+
}
|
|
21642
|
+
@keyframes indeterminate-move {
|
|
21643
|
+
0% {
|
|
21644
|
+
transform: translateX(-100%);
|
|
21645
|
+
}
|
|
21646
|
+
50% {
|
|
21647
|
+
transform: translateX(0);
|
|
21648
|
+
}
|
|
21649
|
+
100% {
|
|
21650
|
+
transform: translateX(100%);
|
|
21651
|
+
}
|
|
21652
|
+
}
|
|
21653
|
+
@keyframes skeleton-loading {
|
|
21654
|
+
0% {
|
|
21655
|
+
left: -100%;
|
|
21656
|
+
}
|
|
21657
|
+
100% {
|
|
21658
|
+
left: 100%;
|
|
21659
|
+
}
|
|
21660
|
+
}
|
|
21661
|
+
/**
|
|
21662
|
+
* -----------------------------------------------------
|
|
21663
|
+
* _breakpoints.scss
|
|
21664
|
+
* -----------------------------------------------------
|
|
21665
|
+
* These constants define the standard device-width breakpoints
|
|
21666
|
+
* used in responsive media queries throughout the theme.
|
|
21667
|
+
*
|
|
21668
|
+
* - $breakpoint-xs: 320px (Extra small, portrait phones)
|
|
21669
|
+
* - $breakpoint-sm: 480px (Small devices, larger phones)
|
|
21670
|
+
* - $breakpoint-md: 768px (Medium devices, tablets)
|
|
21671
|
+
* - $breakpoint-lg: 1024px (Large devices, desktops)
|
|
21672
|
+
* - $breakpoint-xl: 1280px (Extra large desktops)
|
|
21673
|
+
* - $breakpoint-xxl: 1536px (Widescreens, large monitors)
|
|
21674
|
+
*
|
|
21675
|
+
* $breakpoints map:
|
|
21676
|
+
* Use this map to loop over breakpoints or access named values.
|
|
21677
|
+
*/
|
|
21678
|
+
*, *::before, *::after {
|
|
21679
|
+
box-sizing: border-box;
|
|
21680
|
+
}
|
|
21681
|
+
|
|
21682
|
+
body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
|
|
21683
|
+
margin: 0;
|
|
21684
|
+
}
|
|
21685
|
+
|
|
21686
|
+
ul[role=list], ol[role=list] {
|
|
21687
|
+
list-style: none;
|
|
21688
|
+
}
|
|
21689
|
+
|
|
21690
|
+
html:focus-within {
|
|
21691
|
+
scroll-behavior: smooth;
|
|
21692
|
+
}
|
|
21693
|
+
|
|
21694
|
+
body {
|
|
21695
|
+
min-height: 100vh;
|
|
21696
|
+
text-rendering: optimizeSpeed;
|
|
21697
|
+
line-height: 1.5;
|
|
21698
|
+
}
|
|
21699
|
+
|
|
21700
|
+
a:not([class]) {
|
|
21701
|
+
text-decoration-skip-ink: auto;
|
|
21702
|
+
}
|
|
21703
|
+
|
|
21704
|
+
img, picture {
|
|
21705
|
+
max-width: 100%;
|
|
21706
|
+
display: block;
|
|
21707
|
+
}
|
|
21708
|
+
|
|
21709
|
+
input, button, textarea, select {
|
|
21710
|
+
font: inherit;
|
|
21711
|
+
}
|
|
21712
|
+
|
|
21713
|
+
@media (prefers-reduced-motion: reduce) {
|
|
21714
|
+
html:focus-within {
|
|
21715
|
+
scroll-behavior: auto;
|
|
21716
|
+
}
|
|
21717
|
+
*, *::before, *::after {
|
|
21718
|
+
animation-duration: 0.01ms !important;
|
|
21719
|
+
animation-iteration-count: 1 !important;
|
|
21720
|
+
transition-duration: 0.01ms !important;
|
|
21721
|
+
scroll-behavior: auto !important;
|
|
21722
|
+
}
|
|
21723
|
+
}
|
|
21724
|
+
:root {
|
|
21725
|
+
--primary-color: #1c4d3a;
|
|
21726
|
+
--primary-color-light: rgb(107.6, 201.4, 165.0285714286);
|
|
21727
|
+
--primary-color-hover: rgb(14.4, 39.6, 29.8285714286);
|
|
21728
|
+
--text-color-primary: rgb(255, 255, 255);
|
|
21729
|
+
--primary-text-color-contrast: rgb(0, 0, 0);
|
|
21730
|
+
--success-color: #51c703;
|
|
21731
|
+
--warning-color: #fca505;
|
|
21732
|
+
--error-color: #f83838;
|
|
21733
|
+
--secondary-color: #6e502e;
|
|
21734
|
+
--secondary-color-light: rgb(210.7692307692, 181.9230769231, 149.2307692308);
|
|
21735
|
+
--secondary-color-hover: rgb(74.0384615385, 53.8461538462, 30.9615384615);
|
|
21736
|
+
--secondary-text-color: rgb(0, 0, 0);
|
|
21737
|
+
--tertiary-color: #092b1c;
|
|
21738
|
+
--tertiary-color-light: rgb(44.9615384615, 211.0384615385, 137.7692307692);
|
|
21739
|
+
--tertiary-color-hover: rgb(0.1730769231, 0.8269230769, 0.5384615385);
|
|
21740
|
+
--tertiary-text-color: rgb(255, 255, 255);
|
|
21741
|
+
--quaternary-color: #a1733a;
|
|
21742
|
+
--quaternary-color-light: rgb(231.9589041096, 213.6849315068, 191.0410958904);
|
|
21743
|
+
--quaternary-color-hover: rgb(123.5068493151, 88.2191780822, 44.4931506849);
|
|
21744
|
+
--quaternary-text-color: rgb(255, 255, 255);
|
|
21745
|
+
--background-color: #222e2e;
|
|
21746
|
+
--background-color-light: rgb(55.675, 75.325, 75.325);
|
|
21747
|
+
--background-color-lighter: rgb(77.35, 104.65, 104.65);
|
|
21748
|
+
--background-color-dark: rgb(12.325, 16.675, 16.675);
|
|
21749
|
+
--background-color-darker: hsl(180, 15%, -4.3137254902%);
|
|
21750
|
+
--text-color: rgb(255, 255, 255);
|
|
21751
|
+
--text-color-light: hsl(0, 0%, 120%);
|
|
21752
|
+
--text-color-lighter: hsl(0, 0%, 140%);
|
|
21753
|
+
--link-color: #8bb0c7;
|
|
21754
|
+
--link-hover-color: #627e8f;
|
|
21755
|
+
--link-hover-color-primary: rgb(22.4, 61.6, 46.4);
|
|
21756
|
+
--link-hover-color-secondary: rgb(88, 64, 36.8);
|
|
21757
|
+
--focus-outline-color: theme.$primary-color;
|
|
21758
|
+
}
|
|
21759
|
+
|
|
21760
|
+
body {
|
|
21761
|
+
font-family: "Lora", arial, sans-serif;
|
|
21762
|
+
font-size: 18px;
|
|
21763
|
+
color: var(--text-color-primary);
|
|
21764
|
+
background-color: var(--background-color);
|
|
21765
|
+
margin: 0;
|
|
21766
|
+
padding: 0;
|
|
21767
|
+
line-height: 1.5;
|
|
21768
|
+
overflow-x: hidden;
|
|
21769
|
+
transition: background-color 0.3s ease-in-out, color 0.3s ease-in-out;
|
|
21770
|
+
}
|
|
21771
|
+
|
|
21772
|
+
h1,
|
|
21773
|
+
h2,
|
|
21774
|
+
h3,
|
|
21775
|
+
h4,
|
|
21776
|
+
h5,
|
|
21777
|
+
h6 {
|
|
21778
|
+
font-family: "Lora", arial, sans-serif;
|
|
21779
|
+
margin: 0;
|
|
21780
|
+
font-weight: 700;
|
|
21781
|
+
transition: color 0.3s ease-in-out;
|
|
21782
|
+
}
|
|
21783
|
+
|
|
21784
|
+
h1 {
|
|
21785
|
+
font-size: 32px;
|
|
21786
|
+
font-weight: 900;
|
|
21787
|
+
line-height: 1.2;
|
|
21788
|
+
}
|
|
21789
|
+
|
|
21790
|
+
h2 {
|
|
21791
|
+
font-size: 24px;
|
|
21792
|
+
font-weight: 900;
|
|
21793
|
+
line-height: 1.3;
|
|
21794
|
+
}
|
|
21795
|
+
|
|
21796
|
+
h3 {
|
|
21797
|
+
font-size: 16px;
|
|
21798
|
+
line-height: 1.4;
|
|
21799
|
+
}
|
|
21800
|
+
|
|
21801
|
+
h4 {
|
|
21802
|
+
font-size: 18px;
|
|
21803
|
+
line-height: 1.5;
|
|
21804
|
+
}
|
|
21805
|
+
|
|
21806
|
+
h5,
|
|
21807
|
+
h6 {
|
|
21808
|
+
font-size: 14px;
|
|
21809
|
+
line-height: 1.6;
|
|
21810
|
+
font-weight: 400;
|
|
21811
|
+
}
|
|
21812
|
+
|
|
21813
|
+
h6 {
|
|
21814
|
+
text-transform: uppercase;
|
|
21815
|
+
}
|
|
21816
|
+
|
|
21817
|
+
p {
|
|
21818
|
+
font-size: 18px;
|
|
21819
|
+
line-height: 1.6;
|
|
21820
|
+
font-weight: 500;
|
|
21821
|
+
margin-bottom: 16px;
|
|
21822
|
+
}
|
|
21823
|
+
|
|
21824
|
+
a {
|
|
21825
|
+
color: var(--link-color);
|
|
21826
|
+
font-weight: 700;
|
|
21827
|
+
text-decoration: none;
|
|
21828
|
+
transition: color 0.3s ease-in-out, text-decoration 0.3s ease-in-out;
|
|
21829
|
+
}
|
|
21830
|
+
a:hover {
|
|
21831
|
+
color: var(--link-color-hover);
|
|
21832
|
+
text-decoration: underline;
|
|
21833
|
+
}
|
|
21834
|
+
|
|
21835
|
+
.noScroll {
|
|
21836
|
+
overflow: hidden;
|
|
21837
|
+
}
|
|
21838
|
+
|
|
21839
|
+
.errorMessage {
|
|
21840
|
+
color: #f83838;
|
|
21841
|
+
font-size: 14px;
|
|
21842
|
+
}
|
|
21843
|
+
|
|
21844
|
+
.loadingContainer {
|
|
21845
|
+
min-height: 100vh;
|
|
21846
|
+
display: flex;
|
|
21847
|
+
justify-content: center;
|
|
21848
|
+
align-items: center;
|
|
21849
|
+
font-size: 1.5rem;
|
|
21850
|
+
}
|
|
21851
|
+
|
|
21852
|
+
* {
|
|
21853
|
+
scrollbar-width: thin;
|
|
21854
|
+
scrollbar-color: var(--primary-color) var(--background-color-light);
|
|
21855
|
+
}
|
|
21856
|
+
|
|
21857
|
+
*:focus {
|
|
21858
|
+
outline: 2px solid var(--focus-outline-color);
|
|
21859
|
+
outline-offset: 2px;
|
|
21860
|
+
}
|
|
21861
|
+
|
|
21862
|
+
::-webkit-scrollbar {
|
|
21863
|
+
width: 12px;
|
|
21864
|
+
height: 12px;
|
|
21865
|
+
}
|
|
21866
|
+
|
|
21867
|
+
::-webkit-scrollbar-track {
|
|
21868
|
+
background: var(--background-color);
|
|
21869
|
+
}
|
|
21870
|
+
|
|
21871
|
+
::-webkit-scrollbar-thumb {
|
|
21872
|
+
background-color: var(--primary-color);
|
|
21873
|
+
border-radius: 6px;
|
|
21874
|
+
border: 3px solid var(--background-color-light);
|
|
21875
|
+
}
|
|
21876
|
+
|
|
21877
|
+
::-webkit-scrollbar-thumb:hover {
|
|
21878
|
+
background-color: var(--primary-color-hover);
|
|
21879
|
+
}
|
|
21880
|
+
|
|
21881
|
+
.hideScrollbar {
|
|
21882
|
+
scrollbar-width: none;
|
|
21883
|
+
-ms-overflow-style: none;
|
|
21884
|
+
}
|
|
21885
|
+
|
|
21886
|
+
.hideScrollbar::-webkit-scrollbar {
|
|
21887
|
+
display: none;
|
|
21888
|
+
}
|
|
21889
|
+
|
|
21890
|
+
.sr_only {
|
|
21891
|
+
position: absolute;
|
|
21892
|
+
width: 1px;
|
|
21893
|
+
height: 1px;
|
|
21894
|
+
margin: -1px;
|
|
21895
|
+
overflow: hidden;
|
|
21896
|
+
clip: rect(0 0 0 0);
|
|
21897
|
+
white-space: nowrap;
|
|
21898
|
+
border: 0;
|
|
21899
|
+
}
|
|
21900
|
+
|
|
21901
|
+
:global(.sr_only) {
|
|
21902
|
+
position: absolute;
|
|
21903
|
+
width: 1px;
|
|
21904
|
+
height: 1px;
|
|
21905
|
+
margin: -1px;
|
|
21906
|
+
overflow: hidden;
|
|
21907
|
+
clip: rect(0 0 0 0);
|
|
21908
|
+
white-space: nowrap;
|
|
21909
|
+
border: 0;
|
|
21910
|
+
}
|
|
21911
|
+
|
|
21199
21912
|
.slider_container {
|
|
21200
21913
|
display: flex;
|
|
21201
21914
|
flex-direction: column;
|