1078 lines
26 KiB
CSS
1078 lines
26 KiB
CSS
:root {
|
|
--bg: #10151f;
|
|
--bg-elevated: #161d29;
|
|
--surface: rgba(248, 242, 232, 0.95);
|
|
--surface-strong: #f7efe3;
|
|
--surface-muted: rgba(255, 248, 240, 0.74);
|
|
--surface-deep: rgba(20, 27, 39, 0.84);
|
|
--border: rgba(98, 116, 146, 0.22);
|
|
--border-strong: rgba(52, 68, 96, 0.28);
|
|
--text: #19202b;
|
|
--text-secondary: #5b6473;
|
|
--text-on-dark: #eef3fb;
|
|
--accent: #51d0ff;
|
|
--accent-strong: #1097c8;
|
|
--accent-warm: #ff9c52;
|
|
--accent-soft: rgba(81, 208, 255, 0.12);
|
|
--success: #0f766e;
|
|
--warning: #92400e;
|
|
--radius-sm: 0.7rem;
|
|
--radius-md: 1.1rem;
|
|
--radius-lg: 1.6rem;
|
|
--radius-xl: 2rem;
|
|
--shadow-sm: 0 18px 40px rgba(5, 10, 20, 0.08);
|
|
--shadow-md: 0 30px 80px rgba(5, 10, 20, 0.18);
|
|
--shadow-glow: 0 0 0 1px rgba(255,255,255,0.04), 0 24px 80px rgba(10, 20, 40, 0.45);
|
|
}
|
|
|
|
html {
|
|
scroll-behavior: smooth;
|
|
}
|
|
|
|
body {
|
|
background:
|
|
radial-gradient(circle at top left, rgba(81, 208, 255, 0.18), transparent 24%),
|
|
radial-gradient(circle at 85% 12%, rgba(255, 156, 82, 0.16), transparent 20%),
|
|
linear-gradient(180deg, #0e141d 0%, #151d29 48%, #0f141d 100%);
|
|
color: var(--text);
|
|
font-family: Inter, "Cairo", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Tahoma, sans-serif;
|
|
min-height: 100vh;
|
|
}
|
|
|
|
[lang="ar"],
|
|
[dir="rtl"] {
|
|
font-family: "Cairo", "Segoe UI", Tahoma, Arial, sans-serif;
|
|
line-height: 1.85;
|
|
text-align: start;
|
|
unicode-bidi: plaintext;
|
|
}
|
|
|
|
[lang="ar"] .display-6,
|
|
[lang="ar"] .display-5,
|
|
[lang="ar"] .h3,
|
|
[lang="ar"] .h4,
|
|
[lang="ar"] .h5,
|
|
[dir="rtl"] .display-6,
|
|
[dir="rtl"] .display-5,
|
|
[dir="rtl"] .h3,
|
|
[dir="rtl"] .h4,
|
|
[dir="rtl"] .h5 {
|
|
letter-spacing: 0;
|
|
}
|
|
|
|
[lang="ar"] h1,
|
|
[lang="ar"] h2,
|
|
[lang="ar"] h3,
|
|
[lang="ar"] h4,
|
|
[lang="ar"] h5,
|
|
[lang="ar"] h6,
|
|
[dir="rtl"] h1,
|
|
[dir="rtl"] h2,
|
|
[dir="rtl"] h3,
|
|
[dir="rtl"] h4,
|
|
[dir="rtl"] h5,
|
|
[dir="rtl"] h6 {
|
|
font-family: "Cairo", "Segoe UI", Tahoma, Arial, sans-serif;
|
|
font-weight: 700;
|
|
line-height: 1.45;
|
|
}
|
|
|
|
::selection {
|
|
background: rgba(81, 208, 255, 0.28);
|
|
}
|
|
|
|
.app-shell {
|
|
min-height: 100vh;
|
|
position: relative;
|
|
overflow: clip;
|
|
}
|
|
|
|
.library-backdrop {
|
|
position: fixed;
|
|
inset: 0;
|
|
pointer-events: none;
|
|
z-index: 0;
|
|
}
|
|
|
|
.backdrop-orb,
|
|
.backdrop-column,
|
|
.backdrop-grid,
|
|
.backdrop-books,
|
|
.backdrop-scripture {
|
|
position: absolute;
|
|
}
|
|
|
|
.backdrop-orb {
|
|
border-radius: 999px;
|
|
filter: blur(8px);
|
|
opacity: 0.9;
|
|
}
|
|
|
|
.orb-cyan {
|
|
width: 28rem;
|
|
height: 28rem;
|
|
top: -8rem;
|
|
left: -6rem;
|
|
background: radial-gradient(circle, rgba(81, 208, 255, 0.30) 0%, rgba(81, 208, 255, 0.05) 58%, transparent 74%);
|
|
}
|
|
|
|
.orb-amber {
|
|
width: 22rem;
|
|
height: 22rem;
|
|
right: -4rem;
|
|
top: 18rem;
|
|
background: radial-gradient(circle, rgba(255, 156, 82, 0.22) 0%, rgba(255, 156, 82, 0.03) 62%, transparent 78%);
|
|
}
|
|
|
|
.backdrop-grid {
|
|
inset: 0;
|
|
background-image:
|
|
linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
|
|
linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
|
|
background-size: 72px 72px;
|
|
mask-image: linear-gradient(180deg, rgba(0,0,0,0.35), transparent 70%);
|
|
opacity: 0.35;
|
|
}
|
|
|
|
.backdrop-books {
|
|
inset-inline: clamp(1rem, 3vw, 3rem);
|
|
bottom: 1.5rem;
|
|
height: min(46vw, 27rem);
|
|
opacity: 0.24;
|
|
background-repeat: no-repeat;
|
|
background-position: left bottom, right 5% bottom 1rem;
|
|
background-size: min(40rem, 52vw) auto, min(32rem, 42vw) auto;
|
|
background-image:
|
|
url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 900 520'%3E%3Cdefs%3E%3ClinearGradient id='page' x1='0' x2='1' y1='0' y2='1'%3E%3Cstop stop-color='%23fff7ea'/%3E%3Cstop offset='1' stop-color='%23d8c0a2'/%3E%3C/linearGradient%3E%3ClinearGradient id='cover' x1='0' x2='1' y1='0' y2='1'%3E%3Cstop stop-color='%236a4127'/%3E%3Cstop offset='1' stop-color='%231e1712'/%3E%3C/linearGradient%3E%3ClinearGradient id='shadow' x1='0' x2='0' y1='0' y2='1'%3E%3Cstop stop-color='%23000000' stop-opacity='.34'/%3E%3Cstop offset='1' stop-color='%23000000' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cellipse cx='440' cy='438' rx='300' ry='44' fill='%23080b11' fill-opacity='.4'/%3E%3Cpath d='M122 357c49-109 125-160 236-180 38-7 86 6 121 28 32 20 56 52 76 104-110-29-219-24-336 12-31 10-61 22-97 36z' fill='url(%23cover)'/%3E%3Cpath d='M568 312c41-48 78-77 118-88 42-12 77-6 109 19 21 16 38 42 51 78-57-11-116-12-178-4-49 7-84 4-100-5z' fill='url(%23cover)' opacity='.92'/%3E%3Cpath d='M160 344c87-92 167-130 268-138 59-4 110 17 152 65-61 5-126 14-193 31-73 18-145 38-227 42z' fill='url(%23page)'/%3E%3Cpath d='M573 305c65-52 124-71 180-58 35 8 64 29 87 66-35-2-71-1-107 2-56 6-109 16-160 31z' fill='url(%23page)'/%3E%3Cpath d='M426 215c5 51 10 97 18 137' stroke='%23825f43' stroke-width='10' stroke-linecap='round' opacity='.55'/%3E%3Cg stroke='%239d7753' stroke-width='5' stroke-linecap='round' opacity='.45'%3E%3Cpath d='M240 298c49-24 95-35 139-34'/%3E%3Cpath d='M223 324c63-27 124-39 183-38'/%3E%3Cpath d='M207 351c77-28 152-39 225-36'/%3E%3Cpath d='M631 287c39-13 77-18 114-13'/%3E%3Cpath d='M616 311c54-16 107-22 157-18'/%3E%3Cpath d='M600 337c66-16 127-19 183-12'/%3E%3C/g%3E%3Cg fill='none' stroke='%23623f2a' stroke-width='4' opacity='.55'%3E%3Cpath d='M275 287c26-15 55-22 88-18'/%3E%3Cpath d='M295 313c34-14 67-16 100-8'/%3E%3Cpath d='M312 338c37-13 72-13 106-3'/%3E%3Cpath d='M655 286c23-7 46-6 68 2'/%3E%3Cpath d='M669 311c30-9 59-8 87 4'/%3E%3Cpath d='M684 336c30-7 58-4 84 9'/%3E%3C/g%3E%3Cpath d='M146 356c103 8 200-14 292-41 63-19 120-30 172-34' stroke='url(%23shadow)' stroke-width='24' stroke-linecap='round' opacity='.35'/%3E%3C/svg%3E"),
|
|
url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 760 460'%3E%3Cdefs%3E%3ClinearGradient id='page2' x1='0' x2='1' y1='0' y2='1'%3E%3Cstop stop-color='%23fbf1df'/%3E%3Cstop offset='1' stop-color='%23cfb18b'/%3E%3C/linearGradient%3E%3ClinearGradient id='cover2' x1='0' x2='1' y1='0' y2='1'%3E%3Cstop stop-color='%23502d1c'/%3E%3Cstop offset='1' stop-color='%23130f0c'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cellipse cx='384' cy='404' rx='214' ry='32' fill='%23080b11' fill-opacity='.32'/%3E%3Cpath d='M168 303c76-65 140-95 212-101 49-4 93 12 131 49-49 5-102 15-158 31-58 17-120 27-185 21z' fill='url(%23page2)'/%3E%3Cpath d='M504 283c39-39 80-60 124-65 38-5 72 11 102 48-28 0-61 5-100 14-39 10-81 18-126 25z' fill='url(%23page2)'/%3E%3Cpath d='M156 316c40-53 85-85 133-96 52-13 106-5 163 25-71 3-139 16-204 39-25 9-56 20-92 32z' fill='url(%23cover2)' opacity='.95'/%3E%3Cpath d='M502 289c44-31 86-46 126-44 31 1 58 17 82 47-32 1-67 6-103 16-34 10-69 17-105 22z' fill='url(%23cover2)' opacity='.95'/%3E%3Cg fill='none' stroke='%23765437' stroke-width='4' stroke-linecap='round' opacity='.45'%3E%3Cpath d='M244 274c38-18 76-25 116-19'/%3E%3Cpath d='M224 298c56-18 110-24 163-18'/%3E%3Cpath d='M208 325c66-18 128-23 188-14'/%3E%3Cpath d='M550 270c27-7 54-8 81-2'/%3E%3Cpath d='M539 296c38-8 74-7 108 3'/%3E%3Cpath d='M529 321c46-8 89-4 129 10'/%3E%3C/g%3E%3Cg fill='none' stroke='%23573a2a' stroke-width='3.5' opacity='.52'%3E%3Cpath d='M270 262c20-13 42-17 66-13'/%3E%3Cpath d='M282 287c28-11 54-12 81-5'/%3E%3Cpath d='M294 311c29-10 56-9 83-1'/%3E%3Cpath d='M576 267c17-5 34-4 50 2'/%3E%3Cpath d='M584 291c22-6 43-4 64 4'/%3E%3Cpath d='M592 315c23-5 45-2 66 7'/%3E%3C/svg%3E");
|
|
filter: saturate(0.9) blur(0.2px);
|
|
mix-blend-mode: screen;
|
|
}
|
|
|
|
.backdrop-scripture {
|
|
inset-inline: 5%;
|
|
bottom: 0;
|
|
height: min(38vw, 20rem);
|
|
opacity: 0.14;
|
|
background-repeat: repeat-x;
|
|
background-position: center bottom;
|
|
background-size: min(36rem, 46vw) auto;
|
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 900 160'%3E%3Cg fill='none' stroke='%23f8d7b2' stroke-linecap='round' stroke-width='5' opacity='.72'%3E%3Cpath d='M40 96c19-18 34-27 49-29 14-2 30 3 47 16 18 13 34 15 48 4 12-9 18-17 27-38 5 28 18 45 38 50 20 5 41-3 62-26 14-15 29-22 46-21 16 1 29 9 39 24 13 20 29 30 48 29 23-2 44-17 65-47 10 17 21 29 33 35 23 11 48 4 75-21 21-19 41-28 61-27 19 2 35 15 50 41 13 23 31 34 54 35 22 1 43-12 64-38 16-21 35-30 56-28 18 2 35 14 49 36'/%3E%3Cpath d='M24 122c24-15 42-21 56-17 16 4 30 16 42 35 12-22 28-32 47-30 18 3 33 15 46 37 10-19 23-28 39-28 15 0 28 9 40 26 11-18 25-27 43-26 18 1 35 12 50 33 10-16 24-24 42-23 18 2 35 14 49 37 12-24 31-35 55-35 22 1 39 13 52 35 12-23 27-34 47-34 18 1 33 12 47 31 12-20 26-29 42-29 17 1 33 13 47 36 11-15 23-22 37-22 16 0 34 10 55 32'/%3E%3C/g%3E%3C/svg%3E");
|
|
mask-image: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.7) 32%, rgba(0,0,0,1) 100%);
|
|
}
|
|
|
|
html[lang="ar"] .backdrop-books,
|
|
html[dir="rtl"] .backdrop-books {
|
|
opacity: 0.3;
|
|
background-position: right bottom, left 6% bottom 1rem;
|
|
}
|
|
|
|
html[lang="ar"] .backdrop-scripture,
|
|
html[dir="rtl"] .backdrop-scripture {
|
|
opacity: 0.2;
|
|
transform: scaleX(-1);
|
|
}
|
|
|
|
.backdrop-column {
|
|
width: 13rem;
|
|
height: 42rem;
|
|
border-radius: 999px;
|
|
background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
|
|
border: 1px solid rgba(255,255,255,0.08);
|
|
transform: rotate(24deg);
|
|
filter: blur(0.4px);
|
|
}
|
|
|
|
.column-left {
|
|
left: -3rem;
|
|
bottom: -18rem;
|
|
}
|
|
|
|
.column-right {
|
|
right: -1rem;
|
|
top: 5rem;
|
|
transform: rotate(-22deg);
|
|
}
|
|
|
|
.library-topbar,
|
|
.library-main,
|
|
.library-footer {
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.library-topbar > .container,
|
|
.library-main > .container,
|
|
.library-footer > .container {
|
|
width: min(980px, calc(100% - clamp(3rem, 9vw, 10rem)));
|
|
max-width: 980px;
|
|
margin-inline: auto;
|
|
}
|
|
|
|
.library-nav-shell {
|
|
margin-top: 0.5rem;
|
|
border: 1px solid rgba(255,255,255,0.08);
|
|
background: rgba(16, 22, 34, 0.66);
|
|
backdrop-filter: blur(20px);
|
|
box-shadow: var(--shadow-glow);
|
|
border-radius: 999px;
|
|
padding-inline: 0.9rem;
|
|
min-height: 4.1rem;
|
|
}
|
|
|
|
.navbar-toggler {
|
|
border-color: rgba(255,255,255,0.18);
|
|
background: rgba(255,255,255,0.06);
|
|
}
|
|
|
|
.navbar-toggler-icon {
|
|
filter: invert(1);
|
|
}
|
|
|
|
.brand-mark {
|
|
width: 2.6rem;
|
|
height: 2.6rem;
|
|
border-radius: 0.9rem;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
background: linear-gradient(135deg, var(--accent), var(--accent-warm));
|
|
color: #07111b;
|
|
font-weight: 800;
|
|
letter-spacing: 0.08em;
|
|
font-size: 0.82rem;
|
|
box-shadow: 0 12px 28px rgba(81, 208, 255, 0.25);
|
|
flex-shrink: 0;
|
|
}
|
|
|
|
.brand-logo {
|
|
width: 2.9rem;
|
|
height: 2.9rem;
|
|
border-radius: 0.95rem;
|
|
object-fit: cover;
|
|
flex-shrink: 0;
|
|
border: 1px solid rgba(255,255,255,0.16);
|
|
background: rgba(255,255,255,0.96);
|
|
box-shadow: 0 16px 36px rgba(5, 10, 20, 0.2);
|
|
}
|
|
|
|
.brand-lockup {
|
|
min-width: 0;
|
|
}
|
|
|
|
.brand-title {
|
|
font-weight: 800;
|
|
color: var(--text-on-dark);
|
|
line-height: 1.1;
|
|
letter-spacing: -0.03em;
|
|
}
|
|
|
|
.navbar small,
|
|
.footer-copy,
|
|
.footer-links,
|
|
.footer-links a,
|
|
.text-secondary {
|
|
color: var(--text-secondary) !important;
|
|
}
|
|
|
|
.nav-link {
|
|
color: rgba(238, 243, 251, 0.74);
|
|
font-weight: 700;
|
|
border-radius: 999px;
|
|
padding-inline: 0.95rem !important;
|
|
padding-block: 0.65rem !important;
|
|
transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
|
|
}
|
|
|
|
.nav-link.active,
|
|
.nav-link:hover,
|
|
.nav-link:focus {
|
|
color: var(--text-on-dark);
|
|
background: rgba(255,255,255,0.08);
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.topbar-lang-switch {
|
|
border-radius: 999px;
|
|
padding-inline: 1rem;
|
|
font-weight: 700;
|
|
line-height: 1.2;
|
|
border-color: rgba(255,255,255,0.16);
|
|
color: var(--text-on-dark);
|
|
background: rgba(255,255,255,0.05);
|
|
}
|
|
|
|
.topbar-lang-switch:hover,
|
|
.topbar-lang-switch:focus {
|
|
background: linear-gradient(135deg, rgba(81, 208, 255, 0.2), rgba(255, 156, 82, 0.18));
|
|
border-color: rgba(255,255,255,0.2);
|
|
color: #fff;
|
|
}
|
|
|
|
.library-stage {
|
|
position: relative;
|
|
padding-top: clamp(0.85rem, 1.8vw, 1.25rem) !important;
|
|
padding-bottom: clamp(2rem, 3vw, 2.8rem) !important;
|
|
}
|
|
|
|
.hero-surface,
|
|
.panel {
|
|
background: var(--surface);
|
|
border: 1px solid rgba(255,255,255,0.52);
|
|
border-radius: var(--radius-lg);
|
|
box-shadow: var(--shadow-sm);
|
|
backdrop-filter: blur(10px);
|
|
}
|
|
|
|
.hero-surface {
|
|
padding: clamp(1.5rem, 2.4vw, 2.1rem);
|
|
}
|
|
|
|
.panel {
|
|
padding: 1.35rem;
|
|
}
|
|
|
|
.eyebrow,
|
|
.section-kicker {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 0.45rem;
|
|
color: var(--accent-strong);
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.12em;
|
|
font-size: 0.72rem;
|
|
font-weight: 800;
|
|
margin-bottom: 0.9rem;
|
|
}
|
|
|
|
.display-6,
|
|
.display-5,
|
|
.h3,
|
|
.h4,
|
|
.h5 {
|
|
letter-spacing: -0.045em;
|
|
}
|
|
|
|
.display-5 {
|
|
font-weight: 800;
|
|
}
|
|
|
|
.lead {
|
|
font-size: 1.06rem;
|
|
}
|
|
|
|
.hero-surface--immersive {
|
|
position: relative;
|
|
overflow: hidden;
|
|
padding: clamp(1.4rem, 2.3vw, 2rem);
|
|
border-radius: var(--radius-xl);
|
|
}
|
|
|
|
.hero-surface--immersive::before {
|
|
content: "";
|
|
position: absolute;
|
|
inset: 0;
|
|
background:
|
|
radial-gradient(circle at top right, rgba(81, 208, 255, 0.16), transparent 34%),
|
|
radial-gradient(circle at bottom left, rgba(255, 156, 82, 0.14), transparent 28%);
|
|
pointer-events: none;
|
|
}
|
|
|
|
.hero-surface--immersive > * {
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.hero-copy-wrap {
|
|
max-width: 39rem;
|
|
}
|
|
|
|
.hero-surface--immersive > .row {
|
|
--bs-gutter-x: clamp(1rem, 2vw, 1.75rem);
|
|
--bs-gutter-y: 0.85rem;
|
|
}
|
|
|
|
.hero-actions {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 0.85rem;
|
|
}
|
|
|
|
.hero-stat-strip {
|
|
display: grid;
|
|
grid-template-columns: repeat(3, minmax(0, 1fr));
|
|
gap: 0.8rem;
|
|
margin-top: 1.35rem;
|
|
}
|
|
|
|
.hero-stat {
|
|
padding: 1rem 1.1rem;
|
|
border-radius: 1.2rem;
|
|
background: rgba(16, 22, 34, 0.88);
|
|
border: 1px solid rgba(255,255,255,0.08);
|
|
box-shadow: var(--shadow-glow);
|
|
}
|
|
|
|
.hero-stat-value {
|
|
display: block;
|
|
color: var(--text-on-dark);
|
|
font-weight: 800;
|
|
font-size: 1.45rem;
|
|
letter-spacing: -0.05em;
|
|
}
|
|
|
|
.hero-stat-label {
|
|
display: block;
|
|
color: rgba(238, 243, 251, 0.68);
|
|
font-size: 0.9rem;
|
|
}
|
|
|
|
.hero-showcase {
|
|
display: grid;
|
|
gap: 1rem;
|
|
}
|
|
|
|
.curator-card,
|
|
.spotlight-card,
|
|
.discovery-panel,
|
|
.tone-panel,
|
|
.panel-dark {
|
|
border-radius: 1.5rem;
|
|
box-shadow: var(--shadow-md);
|
|
}
|
|
|
|
.curator-card,
|
|
.spotlight-card,
|
|
.discovery-panel,
|
|
.tone-panel {
|
|
background: var(--surface);
|
|
border: 1px solid rgba(255,255,255,0.52);
|
|
}
|
|
|
|
.curator-card {
|
|
padding: 1.4rem;
|
|
}
|
|
|
|
.curator-note {
|
|
color: var(--text-secondary);
|
|
margin-bottom: 1rem;
|
|
}
|
|
|
|
.curator-signature {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 0.85rem;
|
|
}
|
|
|
|
.signature-mark {
|
|
width: 2.8rem;
|
|
height: 2.8rem;
|
|
border-radius: 1rem;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
background: linear-gradient(135deg, rgba(81, 208, 255, 0.2), rgba(255, 156, 82, 0.22));
|
|
color: var(--text);
|
|
font-weight: 800;
|
|
}
|
|
|
|
.signature-name {
|
|
font-weight: 700;
|
|
display: block;
|
|
}
|
|
|
|
.signature-role {
|
|
color: var(--text-secondary);
|
|
font-size: 0.92rem;
|
|
}
|
|
|
|
.spotlight-card {
|
|
padding: 1.35rem;
|
|
background: linear-gradient(180deg, rgba(247, 239, 227, 0.98), rgba(255, 250, 244, 0.92));
|
|
}
|
|
|
|
.spotlight-head {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
gap: 1rem;
|
|
align-items: start;
|
|
margin-bottom: 1rem;
|
|
}
|
|
|
|
.spotlight-badge {
|
|
background: rgba(16, 151, 200, 0.12) !important;
|
|
color: var(--accent-strong) !important;
|
|
border: 1px solid rgba(16, 151, 200, 0.18);
|
|
}
|
|
|
|
.metric-grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(3, minmax(0, 1fr));
|
|
gap: 0.9rem;
|
|
}
|
|
|
|
.metric-grid-compact {
|
|
grid-template-columns: repeat(2, minmax(0, 1fr));
|
|
}
|
|
|
|
.metric-card,
|
|
.recent-card,
|
|
.curated-mini-card {
|
|
background: var(--surface-muted);
|
|
border: 1px solid var(--border);
|
|
border-radius: var(--radius-md);
|
|
padding: 1rem;
|
|
}
|
|
|
|
.metric-card {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 0.25rem;
|
|
}
|
|
|
|
.metric-value {
|
|
font-size: 1.55rem;
|
|
font-weight: 800;
|
|
letter-spacing: -0.04em;
|
|
}
|
|
|
|
.metric-label {
|
|
color: var(--text-secondary);
|
|
font-size: 0.92rem;
|
|
}
|
|
|
|
.compact-list,
|
|
.compact-list-numbered,
|
|
.curated-points {
|
|
color: var(--text-secondary);
|
|
display: grid;
|
|
gap: 0.65rem;
|
|
padding-left: 1.2rem;
|
|
}
|
|
|
|
.compact-list {
|
|
padding-left: 1rem;
|
|
}
|
|
|
|
.compact-list li::marker,
|
|
.compact-list-numbered li::marker,
|
|
.curated-points li::marker {
|
|
color: var(--accent-strong);
|
|
}
|
|
|
|
.discovery-panel {
|
|
padding: 1.5rem;
|
|
}
|
|
|
|
.discovery-form-grid {
|
|
display: grid;
|
|
grid-template-columns: minmax(0, 1.7fr) minmax(0, 0.9fr) auto;
|
|
gap: 1rem;
|
|
}
|
|
|
|
.tone-panel {
|
|
padding: 1.5rem;
|
|
background: linear-gradient(180deg, rgba(250, 244, 236, 0.96), rgba(245, 238, 228, 0.92));
|
|
}
|
|
|
|
.tone-swatch-row {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 0.7rem;
|
|
margin-bottom: 1rem;
|
|
}
|
|
|
|
.tone-swatch {
|
|
width: 3rem;
|
|
height: 3rem;
|
|
border-radius: 1rem;
|
|
border: 1px solid rgba(0,0,0,0.06);
|
|
box-shadow: inset 0 1px 0 rgba(255,255,255,0.35);
|
|
}
|
|
|
|
.tone-swatch.cyan {
|
|
background: linear-gradient(135deg, #7be3ff, #26a8db);
|
|
}
|
|
|
|
.tone-swatch.ivory {
|
|
background: linear-gradient(135deg, #fff9f0, #ece0cf);
|
|
}
|
|
|
|
.tone-swatch.amber {
|
|
background: linear-gradient(135deg, #ffc489, #ef7d37);
|
|
}
|
|
|
|
.catalog-section-head {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
gap: 1rem;
|
|
align-items: end;
|
|
margin-bottom: 1.25rem;
|
|
}
|
|
|
|
.catalog-shell {
|
|
position: relative;
|
|
}
|
|
|
|
.catalog-shell::after {
|
|
content: "";
|
|
position: absolute;
|
|
inset: auto 0 -1.1rem 0;
|
|
height: 1px;
|
|
background: linear-gradient(90deg, transparent, rgba(255,255,255,0.34), transparent);
|
|
opacity: 0.6;
|
|
}
|
|
|
|
.catalog-card {
|
|
display: grid;
|
|
grid-template-columns: 128px minmax(0, 1fr);
|
|
gap: 1.25rem;
|
|
align-items: stretch;
|
|
transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
|
|
}
|
|
|
|
.catalog-card:hover,
|
|
.catalog-card:focus-within {
|
|
transform: translateY(-4px);
|
|
box-shadow: var(--shadow-md);
|
|
border-color: rgba(16, 151, 200, 0.18);
|
|
}
|
|
|
|
.catalog-card-media {
|
|
display: flex;
|
|
}
|
|
|
|
.catalog-card-cover {
|
|
width: 128px;
|
|
min-width: 128px;
|
|
height: 176px;
|
|
object-fit: cover;
|
|
border-radius: var(--radius-md);
|
|
border: 1px solid rgba(16, 22, 34, 0.08);
|
|
background: var(--surface-muted);
|
|
box-shadow: var(--shadow-sm);
|
|
}
|
|
|
|
.catalog-card-cover-placeholder {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
color: var(--text-secondary);
|
|
font-size: 0.9rem;
|
|
font-weight: 700;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.08em;
|
|
}
|
|
|
|
.catalog-card-body {
|
|
min-width: 0;
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
}
|
|
|
|
.catalog-card-title,
|
|
.catalog-card-title-alt {
|
|
overflow-wrap: anywhere;
|
|
}
|
|
|
|
.catalog-card-title-alt {
|
|
font-size: 0.96rem;
|
|
}
|
|
|
|
.catalog-card-badges {
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.catalog-card-meta {
|
|
display: grid;
|
|
gap: 0.65rem;
|
|
}
|
|
|
|
.catalog-card-meta > div {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 0.35rem;
|
|
}
|
|
|
|
.catalog-card-label {
|
|
min-width: 3.75rem;
|
|
color: var(--text);
|
|
font-weight: 700;
|
|
}
|
|
|
|
.recent-card {
|
|
display: block;
|
|
height: 100%;
|
|
transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
|
|
}
|
|
|
|
.recent-card:hover,
|
|
.recent-card:focus {
|
|
transform: translateY(-2px);
|
|
box-shadow: var(--shadow-md);
|
|
border-color: var(--border-strong);
|
|
}
|
|
|
|
.link-arrow,
|
|
.back-link {
|
|
color: var(--text);
|
|
font-weight: 700;
|
|
text-decoration: none;
|
|
}
|
|
|
|
.link-arrow:hover,
|
|
.back-link:hover {
|
|
color: var(--accent-strong);
|
|
}
|
|
|
|
.form-control,
|
|
.form-select {
|
|
border-color: rgba(53, 71, 95, 0.18);
|
|
padding: 0.78rem 0.9rem;
|
|
border-radius: 1rem;
|
|
background: rgba(255,255,255,0.88);
|
|
}
|
|
|
|
.form-control:focus,
|
|
.form-select:focus,
|
|
.btn:focus,
|
|
.nav-link:focus,
|
|
.btn-close:focus {
|
|
box-shadow: 0 0 0 0.2rem rgba(81, 208, 255, 0.16);
|
|
border-color: rgba(16, 151, 200, 0.34);
|
|
}
|
|
|
|
.btn {
|
|
border-radius: 999px;
|
|
padding: 0.8rem 1.15rem;
|
|
font-weight: 700;
|
|
letter-spacing: -0.01em;
|
|
}
|
|
|
|
.btn-dark {
|
|
color: #08131d;
|
|
background: linear-gradient(135deg, var(--accent), var(--accent-warm));
|
|
border: none;
|
|
box-shadow: 0 16px 36px rgba(81, 208, 255, 0.18);
|
|
}
|
|
|
|
.btn-dark:hover,
|
|
.btn-dark:focus {
|
|
color: #08131d;
|
|
background: linear-gradient(135deg, #74ddff, #ffb67f);
|
|
}
|
|
|
|
.btn-outline-secondary,
|
|
.btn-outline-dark {
|
|
color: var(--text);
|
|
border-color: rgba(53, 71, 95, 0.18);
|
|
background: rgba(255,255,255,0.35);
|
|
}
|
|
|
|
.btn-outline-secondary:hover,
|
|
.btn-outline-secondary:focus,
|
|
.btn-outline-dark:hover,
|
|
.btn-outline-dark:focus {
|
|
background: rgba(81, 208, 255, 0.10);
|
|
color: var(--text);
|
|
border-color: rgba(16, 151, 200, 0.20);
|
|
}
|
|
|
|
.badge {
|
|
border-radius: 999px;
|
|
font-weight: 700;
|
|
letter-spacing: 0.01em;
|
|
padding: 0.58em 0.82em;
|
|
}
|
|
|
|
.text-bg-light {
|
|
background: var(--accent-soft) !important;
|
|
color: var(--accent-strong) !important;
|
|
border: 1px solid rgba(16, 151, 200, 0.18);
|
|
}
|
|
|
|
.empty-panel {
|
|
background: rgba(248, 242, 232, 0.72);
|
|
}
|
|
|
|
.empty-icon {
|
|
width: 3rem;
|
|
height: 3rem;
|
|
border-radius: 1rem;
|
|
background: linear-gradient(135deg, rgba(81, 208, 255, 0.18), rgba(255, 156, 82, 0.20));
|
|
border: 1px solid rgba(16, 151, 200, 0.12);
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
font-weight: 800;
|
|
font-size: 1.1rem;
|
|
}
|
|
|
|
.table > :not(caption) > * > * {
|
|
padding-block: 0.95rem;
|
|
border-bottom-color: rgba(53, 71, 95, 0.14);
|
|
}
|
|
|
|
.table thead th {
|
|
color: var(--text-secondary);
|
|
font-size: 0.8rem;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.06em;
|
|
}
|
|
|
|
.reader-panel {
|
|
padding-bottom: 1rem;
|
|
}
|
|
|
|
.reader-frame-wrap {
|
|
border: 1px solid rgba(53, 71, 95, 0.14);
|
|
border-radius: var(--radius-md);
|
|
overflow: hidden;
|
|
background: #d1d5db;
|
|
}
|
|
|
|
.reader-frame {
|
|
width: 100%;
|
|
min-height: 70vh;
|
|
border: 0;
|
|
background: #fff;
|
|
}
|
|
|
|
.reader-lock,
|
|
.summary-box {
|
|
background: rgba(250, 244, 236, 0.88);
|
|
border: 1px solid rgba(53, 71, 95, 0.12);
|
|
border-radius: var(--radius-md);
|
|
padding: 1rem;
|
|
}
|
|
|
|
.summary-box {
|
|
white-space: pre-line;
|
|
line-height: 1.7;
|
|
}
|
|
|
|
.summary-box-muted {
|
|
color: var(--text-secondary);
|
|
}
|
|
|
|
.description-stack {
|
|
display: grid;
|
|
gap: 1rem;
|
|
}
|
|
|
|
.toast {
|
|
min-width: 280px;
|
|
border-radius: 0.95rem;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.toast-stack {
|
|
z-index: 1090;
|
|
}
|
|
|
|
.library-footer {
|
|
padding-bottom: 2rem;
|
|
}
|
|
|
|
.library-footer-panel {
|
|
background: rgba(16, 22, 34, 0.72);
|
|
color: var(--text-on-dark);
|
|
border-radius: 1.6rem;
|
|
border: 1px solid rgba(255,255,255,0.08);
|
|
backdrop-filter: blur(16px);
|
|
box-shadow: var(--shadow-glow);
|
|
}
|
|
|
|
.footer-brand-logo {
|
|
width: 3.35rem;
|
|
height: 3.35rem;
|
|
}
|
|
|
|
.footer-section-title {
|
|
color: rgba(238, 243, 251, 0.88);
|
|
font-weight: 700;
|
|
letter-spacing: 0.02em;
|
|
}
|
|
|
|
.footer-description {
|
|
max-width: 34rem;
|
|
}
|
|
|
|
.footer-detail-list {
|
|
display: grid;
|
|
gap: 0.65rem;
|
|
}
|
|
|
|
.footer-detail-list div {
|
|
display: flex;
|
|
align-items: flex-start;
|
|
gap: 0.7rem;
|
|
}
|
|
|
|
.footer-detail-list i {
|
|
color: var(--accent);
|
|
margin-top: 0.1rem;
|
|
}
|
|
|
|
.footer-socials {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 0.65rem;
|
|
}
|
|
|
|
.footer-socials a {
|
|
width: 2.35rem;
|
|
height: 2.35rem;
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
border-radius: 999px;
|
|
background: rgba(255,255,255,0.08);
|
|
border: 1px solid rgba(255,255,255,0.08);
|
|
transition: transform 0.2s ease, background-color 0.2s ease, color 0.2s ease;
|
|
}
|
|
|
|
.footer-socials a:hover {
|
|
transform: translateY(-1px);
|
|
background: rgba(81, 208, 255, 0.14);
|
|
}
|
|
|
|
.footer-meta-note {
|
|
color: rgba(238, 243, 251, 0.68);
|
|
font-size: 0.85rem;
|
|
}
|
|
|
|
.footer-title,
|
|
footer a {
|
|
color: var(--text-on-dark);
|
|
}
|
|
|
|
.footer-links a:hover {
|
|
color: var(--accent);
|
|
}
|
|
|
|
.profile-hero {
|
|
background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(238,241,244,0.96));
|
|
}
|
|
|
|
.profile-metric-grid {
|
|
grid-template-columns: repeat(4, minmax(0, 1fr));
|
|
}
|
|
|
|
.metric-value-small {
|
|
font-size: 1rem;
|
|
line-height: 1.5;
|
|
letter-spacing: normal;
|
|
}
|
|
|
|
.profile-summary-list dt,
|
|
.profile-summary-list dd {
|
|
line-height: 1.6;
|
|
}
|
|
|
|
.history-card {
|
|
display: block;
|
|
}
|
|
|
|
.history-card-meta {
|
|
display: grid;
|
|
gap: 0.35rem;
|
|
}
|
|
|
|
#flipbook-wrapper {
|
|
background: #333;
|
|
box-shadow: inset 0 0 30px rgba(0,0,0,0.6);
|
|
}
|
|
|
|
#flipbook .page {
|
|
background-color: #fff;
|
|
border-right: 1px solid #ddd;
|
|
}
|
|
|
|
#flipbook-toolbar button {
|
|
transition: all 0.2s ease;
|
|
}
|
|
|
|
#flipbook-toolbar button:hover {
|
|
transform: scale(1.1);
|
|
color: var(--accent-strong);
|
|
}
|
|
|
|
#flipbook-toolbar button:active {
|
|
transform: scale(0.95);
|
|
}
|
|
|
|
@media (max-width: 991.98px) {
|
|
.library-nav-shell {
|
|
border-radius: 1.5rem;
|
|
padding-block: 0.5rem;
|
|
}
|
|
|
|
.backdrop-books {
|
|
inset-inline: -4rem;
|
|
bottom: 3rem;
|
|
opacity: 0.18;
|
|
background-size: 30rem auto, 24rem auto;
|
|
}
|
|
|
|
.backdrop-scripture {
|
|
inset-inline: 0;
|
|
opacity: 0.1;
|
|
background-size: 24rem auto;
|
|
}
|
|
|
|
.hero-stat-strip,
|
|
.metric-grid,
|
|
.profile-metric-grid,
|
|
.discovery-form-grid {
|
|
grid-template-columns: 1fr;
|
|
}
|
|
|
|
.spotlight-head,
|
|
.catalog-section-head {
|
|
flex-direction: column;
|
|
align-items: start;
|
|
}
|
|
|
|
.column-right {
|
|
top: 18rem;
|
|
}
|
|
}
|
|
|
|
@media (max-width: 767.98px) {
|
|
.backdrop-books,
|
|
.backdrop-scripture {
|
|
display: none;
|
|
}
|
|
|
|
.catalog-card {
|
|
grid-template-columns: 1fr;
|
|
}
|
|
|
|
.catalog-card-media {
|
|
justify-content: center;
|
|
}
|
|
|
|
.catalog-card-body {
|
|
text-align: start;
|
|
}
|
|
|
|
.hero-surface--immersive {
|
|
padding: 1.4rem;
|
|
}
|
|
|
|
.brand-title {
|
|
font-size: 0.98rem;
|
|
}
|
|
|
|
.footer-brand {
|
|
flex-direction: column;
|
|
}
|
|
|
|
.reader-frame {
|
|
min-height: 60vh;
|
|
}
|
|
}
|