Files
sapien/src/style.css
2026-05-14 12:44:15 -05:00

2968 lines
58 KiB
CSS

@tailwind base;
@tailwind components;
@tailwind utilities;
:root {
color-scheme: light;
font-family: Inter, ui-sans-serif, system-ui, sans-serif;
}
body {
margin: 0;
background: #000;
}
.hero-bg-layer {
position: absolute;
inset: -5rem 0;
transform: translate3d(0, var(--hero-bg-y, 0px), 0) scale(1.03);
will-change: transform;
}
.hero-fold {
min-height: 100svh;
}
.hero-bg {
opacity: 0;
filter: saturate(1.08) contrast(1.08);
transform: scale(1.08);
transform-origin: center;
transition:
opacity 1600ms ease,
filter 1600ms ease;
will-change: transform, filter, opacity;
}
.hero-bg.is-active {
animation: bg-cinema 6800ms cubic-bezier(0.19, 1, 0.22, 1) both;
opacity: 1;
}
.intro-header {
animation: rise-in 900ms cubic-bezier(0.19, 1, 0.22, 1) 700ms both;
background: linear-gradient(to bottom, rgba(0, 0, 0, 0.72), rgba(0, 0, 0, 0));
pointer-events: none;
}
.intro-header > div {
pointer-events: auto;
}
.header-logo-button {
display: inline-flex;
align-items: center;
border: 0;
background: transparent;
padding: 0;
color: inherit;
cursor: pointer;
}
.intro-copy {
max-width: 100%;
opacity: var(--hero-copy-fade, 1);
transform: translate3d(0, var(--hero-copy-y, 0px), 0);
will-change: transform, opacity;
}
.hero-title {
max-width: 100%;
font-size: clamp(1.72rem, 8.3vw, 6rem);
}
.hero-title-line {
display: block;
overflow: hidden;
white-space: nowrap;
will-change: clip-path, filter, opacity, transform;
}
.hero-title-line-primary {
animation: cinematic-word-in 1250ms cubic-bezier(0.19, 1, 0.22, 1) 760ms both;
}
.hero-title-line-secondary {
animation: cinematic-word-in 1250ms cubic-bezier(0.19, 1, 0.22, 1) 1420ms both;
}
.benefits-cue {
display: inline-flex;
width: max-content;
align-items: center;
align-self: center;
gap: 0.78rem;
padding-bottom: 0.2rem;
color: rgba(250, 250, 250, 0.72);
font-size: 0.68rem;
font-weight: 900;
letter-spacing: 0.22em;
text-decoration: none;
text-transform: uppercase;
animation: benefits-cue-in 900ms cubic-bezier(0.19, 1, 0.22, 1) 1900ms both;
}
.mobile-swipe-cue {
display: flex;
align-items: center;
justify-content: center;
width: 2.8rem;
height: 3.25rem;
}
.hand-icon {
width: 2.45rem;
height: auto;
fill: #fafafa;
filter: drop-shadow(0 0 0.55rem rgba(250, 250, 250, 0.18));
animation: swipe-up-cue 2s ease-in-out infinite;
}
.desktop-scroll-cue {
display: none;
width: 1.1rem;
height: 1.72rem;
justify-content: center;
border: 1px solid rgba(250, 250, 250, 0.42);
border-radius: 999px;
}
.desktop-scroll-cue span {
margin-top: 0.34rem;
width: 0.2rem;
height: 0.42rem;
border-radius: 999px;
background: #f2a900;
animation: mouse-wheel-cue 1500ms ease-in-out infinite;
}
@media (min-width: 768px) {
.mobile-swipe-cue {
display: none;
}
.desktop-scroll-cue {
display: flex;
}
}
.members-get-section {
position: relative;
display: grid;
min-height: 100svh;
align-items: center;
overflow: hidden;
background:
radial-gradient(circle at 16% 50%, rgba(242, 169, 0, 0.08), transparent 24rem),
#050505;
}
.members-get-section::after {
content: "";
position: absolute;
inset: 0;
z-index: 0;
pointer-events: none;
background:
radial-gradient(circle at 50% 50%, transparent 0 38%, rgba(0, 0, 0, 0.6) 72%, rgba(0, 0, 0, 0.95) 100%),
linear-gradient(to bottom, rgba(0, 0, 0, 0.78), transparent 22%, transparent 72%, rgba(0, 0, 0, 0.92));
}
.members-get-section::before {
content: "";
position: absolute;
inset: 0;
z-index: 0;
pointer-events: none;
background-image:
linear-gradient(rgba(250, 250, 250, 0.022) 1px, transparent 1px),
linear-gradient(90deg, rgba(250, 250, 250, 0.022) 1px, transparent 1px);
background-size: 6rem 6rem;
mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.46), transparent 70%);
}
.members-pattern-layer {
position: absolute;
inset: -11rem 34% -11rem -7rem;
z-index: 0;
display: grid;
grid-template-columns: repeat(12, minmax(1.25rem, 1fr));
gap: clamp(0.55rem, 1.2vw, 1rem);
align-items: center;
justify-items: center;
opacity: 0.24;
pointer-events: none;
transform: translate3d(0, var(--members-pattern-y, 0px), 0) rotate(-24deg) scale(1.06);
mask-image:
radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0.9), transparent 72%),
linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.85) 20%, rgba(0, 0, 0, 0.85) 76%, transparent 100%);
will-change: transform;
}
.members-pattern-mark {
display: grid;
width: clamp(1rem, 2.62vw, 2.1rem);
aspect-ratio: 1;
place-items: center;
opacity: 0.36;
transform: rotate(var(--members-pattern-rotate, 0deg)) scale(1);
transform-origin: center;
will-change: transform;
}
.members-pattern-mark:nth-child(3n) {
opacity: 0.28;
}
.members-pattern-mark:nth-child(4n) {
opacity: 0.24;
}
.members-pattern-mark img {
width: 100%;
height: auto;
filter: brightness(1.4) saturate(0) drop-shadow(0 0 1.1rem rgba(242, 169, 0, 0.12));
}
.members-get-inner {
position: relative;
z-index: 2;
display: grid;
width: min(100%, 78rem);
margin-inline: auto;
gap: clamp(1.8rem, 6vw, 5.5rem);
padding: clamp(3rem, 7vw, 5.5rem) 1rem;
}
.members-get-title {
max-width: 12ch;
font-size: clamp(3rem, 9vw, 6.8rem);
font-weight: 950;
letter-spacing: 0;
line-height: 0.84;
text-transform: uppercase;
}
.members-get-pricing {
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
align-items: center;
margin-top: 1.1rem;
}
.members-get-price {
width: fit-content;
border: 1px solid rgba(242, 169, 0, 0.34);
border-radius: 999px;
background: rgba(242, 169, 0, 0.08);
padding: 0.58rem 0.82rem;
color: rgba(242, 169, 0, 0.95);
font-size: 0.78rem;
font-weight: 950;
letter-spacing: 0.22em;
text-transform: uppercase;
}
.btc-price-pill {
display: inline-flex;
width: fit-content;
align-items: center;
justify-content: center;
border: 1px solid rgba(247, 147, 26, 0.55);
border-radius: 999px;
background: rgba(247, 147, 26, 0.16);
padding: 0.58rem 0.82rem;
color: #f7931a;
font-size: 0.78rem;
font-weight: 950;
letter-spacing: 0.12em;
line-height: 1;
text-transform: uppercase;
box-shadow:
inset 0 1px rgba(255, 213, 139, 0.18),
0 0 1.6rem rgba(247, 147, 26, 0.08);
}
.members-get-list {
display: grid;
gap: 0;
border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.members-get-item {
display: grid;
grid-template-columns: auto auto 1fr;
gap: 1rem;
align-items: start;
border-bottom: 1px solid rgba(255, 255, 255, 0.12);
background: transparent;
padding: clamp(0.92rem, 2.2vw, 1.28rem) 0;
}
.members-get-item > span {
display: grid;
min-width: 2.4rem;
color: rgba(242, 169, 0, 0.92);
font-size: 0.72rem;
font-weight: 900;
line-height: 1.9;
}
.list-icon {
display: grid;
width: 1.35rem;
min-width: 1.35rem;
aspect-ratio: 1;
place-items: center;
margin-top: 0.1rem;
}
.list-icon svg {
width: 1.25rem;
height: 1.25rem;
fill: none;
stroke: #fafafa;
stroke-width: 1.8;
stroke-linecap: round;
stroke-linejoin: round;
}
.members-get-item h3 {
margin: 0;
color: #fafafa;
font-size: clamp(1rem, 2.4vw, 1.35rem);
font-weight: 900;
letter-spacing: 0.03em;
text-transform: uppercase;
}
.members-get-item p {
margin: 0.42rem 0 0;
color: rgba(250, 250, 250, 0.58);
font-size: 0.94rem;
line-height: 1.62;
}
@media (min-width: 900px) {
.members-get-inner {
grid-template-columns: minmax(0, 0.9fr) minmax(26rem, 0.74fr);
align-items: center;
padding-inline: 3rem;
}
}
@media (max-width: 700px) {
.members-get-section {
min-height: 100svh;
align-items: center;
}
.members-get-inner {
padding-block: 5.5rem 3rem;
}
.members-pattern-layer {
inset: -7rem 8% -7rem -5rem;
grid-template-columns: repeat(6, minmax(2.1rem, 1fr));
gap: 0.78rem;
opacity: 0.18;
}
.members-pattern-mark {
width: 2.1rem;
}
}
.facilities-section {
position: relative;
display: grid;
min-height: 100svh;
align-items: center;
overflow: hidden;
background:
radial-gradient(circle at 84% 46%, rgba(247, 147, 26, 0.1), transparent 24rem),
linear-gradient(180deg, #050505, #080808 44%, #030303);
}
.facilities-bg-layer {
position: absolute;
inset: -5rem 0;
z-index: 0;
overflow: hidden;
transform: translate3d(0, var(--facilities-bg-y, 0px), 0);
will-change: transform;
}
.facilities-bg {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
opacity: 0;
filter: saturate(0.78) contrast(1.18) brightness(0.55) blur(10px);
transform: scale(1.12);
will-change: opacity, filter, transform;
}
.facilities-bg.is-active {
animation: bg-cinema 7600ms cubic-bezier(0.19, 1, 0.22, 1) both;
}
.facilities-section::before {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
linear-gradient(rgba(250, 250, 250, 0.018) 1px, transparent 1px),
linear-gradient(90deg, rgba(250, 250, 250, 0.018) 1px, transparent 1px);
background-size: 5rem 5rem;
mask-image: radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0.72), transparent 72%);
}
.facilities-section::after {
content: "";
position: absolute;
inset: 0;
pointer-events: none;
background:
radial-gradient(circle at 50% 50%, rgba(247, 147, 26, 0.12), transparent 34%),
linear-gradient(90deg, rgba(0, 0, 0, 0.88), rgba(0, 0, 0, 0.56) 52%, rgba(0, 0, 0, 0.84)),
radial-gradient(circle at 50% 50%, transparent 0 42%, rgba(0, 0, 0, 0.72) 100%),
linear-gradient(to bottom, rgba(0, 0, 0, 0.88), transparent 18%, transparent 80%, rgba(0, 0, 0, 0.9));
}
.facilities-inner {
position: relative;
z-index: 1;
display: grid;
width: min(100%, 78rem);
margin-inline: auto;
gap: clamp(2rem, 7vw, 6rem);
padding: clamp(4rem, 8vw, 6rem) 1rem;
}
.facilities-title {
margin: 0;
color: #fafafa;
font-size: clamp(3.3rem, 10vw, 8rem);
font-weight: 950;
letter-spacing: 0;
line-height: 0.82;
text-align: left;
text-transform: uppercase;
}
.facilities-list {
display: grid;
gap: 0;
border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.facilities-item {
display: grid;
grid-template-columns: auto auto 1fr;
gap: 1rem;
align-items: start;
border-bottom: 1px solid rgba(255, 255, 255, 0.12);
background: transparent;
padding: clamp(0.92rem, 2.2vw, 1.28rem) 0;
}
.facilities-item span {
display: grid;
min-width: 2.4rem;
color: #f7931a;
font-size: 0.72rem;
font-weight: 900;
line-height: 1.9;
}
.facilities-item h3 {
margin: 0;
color: #fafafa;
font-size: clamp(1rem, 2.4vw, 1.35rem);
font-weight: 900;
letter-spacing: 0.03em;
text-transform: uppercase;
}
.facilities-item p {
margin: 0.42rem 0 0;
color: rgba(250, 250, 250, 0.58);
font-size: 0.94rem;
font-weight: 400;
line-height: 1.62;
}
.facilities-copy {
transform: translate3d(0, var(--facilities-copy-y, 0px), 0);
will-change: transform;
}
.facilities-list {
transform: translate3d(0, var(--facilities-list-y, 0px), 0);
will-change: transform;
}
@media (min-width: 900px) {
.facilities-inner {
grid-template-columns: minmax(26rem, 0.78fr) minmax(0, 0.92fr);
align-items: center;
padding-inline: 3rem;
}
.facilities-copy {
display: grid;
justify-items: end;
}
.facilities-title {
text-align: right;
}
}
@media (max-width: 899px) {
.facilities-copy {
order: -1;
}
}
@media (max-width: 700px) {
.facilities-section {
min-height: 100svh;
}
.facilities-inner {
padding-block: 5.5rem 3rem;
}
}
.film-grain {
background-image:
linear-gradient(115deg, transparent 0%, rgba(255, 255, 255, 0.08) 46%, transparent 54%),
repeating-radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.16) 0 1px, transparent 1px 4px);
background-size:
180% 180%,
11px 11px;
animation: grain-shift 800ms steps(2, end) infinite;
}
.scanline {
animation: scanline 1800ms cubic-bezier(0.19, 1, 0.22, 1) 500ms both;
box-shadow: 0 0 46px rgba(242, 169, 0, 0.86);
}
.member-button,
.primary-action,
.secondary-action,
.delete-member {
border-radius: 8px;
font-size: 0.75rem;
font-weight: 800;
letter-spacing: 0.12em;
text-transform: uppercase;
transition:
background-color 180ms ease,
border-color 180ms ease,
color 180ms ease,
transform 180ms ease;
}
.member-button,
.primary-action {
border: 1px solid rgba(242, 169, 0, 0.78);
background: #f2a900;
color: #080808;
padding: 0.78rem 1rem;
}
.member-button:hover,
.primary-action:hover {
background: #ffd166;
transform: translateY(-1px);
}
.ghost-member-button {
border-color: rgba(250, 250, 250, 0.36);
background: transparent;
color: #fafafa;
}
.ghost-member-button:hover {
border-color: rgba(250, 250, 250, 0.62);
background: rgba(250, 250, 250, 0.08);
color: #fafafa;
}
.secondary-action,
.delete-member {
border: 1px solid rgba(255, 255, 255, 0.16);
background: rgba(255, 255, 255, 0.06);
color: rgba(255, 255, 255, 0.76);
padding: 0.72rem 0.92rem;
}
.signin-options {
display: grid;
gap: 0.75rem;
}
.signin-option {
display: flex;
min-height: 4.4rem;
flex-direction: column;
align-items: flex-start;
justify-content: center;
gap: 0.24rem;
text-align: left;
}
.signin-option small {
color: rgba(8, 8, 8, 0.68);
font-size: 0.66rem;
font-weight: 700;
letter-spacing: 0.04em;
text-transform: none;
}
.modal-close {
position: relative;
display: grid;
place-items: center;
flex: 0 0 auto;
width: 2.6rem;
height: 2.6rem;
padding: 0;
border: 1px solid rgba(255, 255, 255, 0.18);
border-radius: 999px;
background: rgba(255, 255, 255, 0.06);
color: rgba(255, 255, 255, 0.78);
transition:
background-color 180ms ease,
border-color 180ms ease,
transform 180ms ease;
}
.modal-close::before,
.modal-close::after {
content: '';
position: absolute;
width: 1rem;
height: 2px;
border-radius: 999px;
background: currentColor;
transform-origin: center;
}
.modal-close::before {
transform: rotate(45deg);
}
.modal-close::after {
transform: rotate(-45deg);
}
.modal-close:hover {
border-color: rgba(255, 255, 255, 0.34);
background: rgba(255, 255, 255, 0.12);
transform: translateY(-1px);
}
.delete-member {
color: rgb(252, 165, 165);
}
.compact-action {
align-items: center;
padding: 0.78rem 0.9rem;
}
.card-backup-actions {
display: flex;
width: 100%;
flex-wrap: wrap;
justify-content: center;
gap: 0.75rem;
}
.card-note {
max-width: 34rem;
margin-inline: auto;
border: 1px solid rgba(242, 169, 0, 0.2);
border-radius: 8px;
background: rgba(242, 169, 0, 0.07);
padding: 0.9rem 1rem;
color: rgba(255, 255, 255, 0.66);
font-size: 0.9rem;
line-height: 1.55;
}
.member-keys {
display: grid;
gap: 0.8rem;
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: rgba(255, 255, 255, 0.055);
padding: 1rem;
}
.member-keys div {
display: grid;
gap: 0.35rem;
}
.member-keys a {
color: #f2a900;
font-weight: 800;
}
.member-key-row {
grid-template-columns: 1fr auto;
align-items: center;
}
.member-key-row span {
grid-column: 1 / -1;
}
.member-keys span {
color: rgba(255, 255, 255, 0.42);
font-size: 0.68rem;
font-weight: 900;
letter-spacing: 0.14em;
text-transform: uppercase;
}
.member-keys code {
min-width: 0;
overflow-wrap: anywhere;
border-radius: 6px;
background: rgba(0, 0, 0, 0.34);
padding: 0.7rem;
color: rgba(255, 255, 255, 0.86);
font-size: 0.78rem;
}
.member-key-row .secondary-action {
display: grid;
width: 4.25rem;
min-width: 4.25rem;
place-items: center;
align-self: stretch;
padding-inline: 0.8rem;
}
.modal-footer {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
gap: 0.75rem;
}
.modal-footer > button {
width: 100%;
min-width: 0;
}
.modal-footer > button:only-child {
grid-column: 1 / -1;
}
.validation-message {
margin-top: 1rem;
}
.membership-area,
.admin-area {
background:
radial-gradient(circle at 15% 0%, rgba(242, 169, 0, 0.12), transparent 30rem),
#050505;
}
.admin-area {
--admin-page-x: clamp(1rem, 4vw, 3rem);
--admin-content-gap: 1.25rem;
border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.admin-shell {
width: 100%;
min-height: 100svh;
padding: 0 var(--admin-page-x) 2rem;
}
.admin-login-area {
min-height: 100svh;
background:
radial-gradient(circle at 50% 0%, rgba(242, 169, 0, 0.16), transparent 28rem),
#030303;
}
.admin-login-card {
border: 1px solid rgba(255, 255, 255, 0.13);
border-radius: 8px;
background:
linear-gradient(145deg, rgba(255, 255, 255, 0.08), transparent 34%),
rgba(8, 8, 8, 0.95);
padding: clamp(1.25rem, 5vw, 2rem);
box-shadow: 0 34px 100px rgba(0, 0, 0, 0.54);
}
.section-kicker {
margin-bottom: 0.85rem;
color: rgba(242, 169, 0, 0.9);
font-size: 0.72rem;
font-weight: 900;
letter-spacing: 0.28em;
text-transform: uppercase;
}
.section-title {
max-width: 42rem;
font-size: clamp(2.4rem, 8vw, 5.8rem);
font-weight: 950;
letter-spacing: 0;
line-height: 0.88;
text-transform: uppercase;
}
.section-copy {
margin-top: 1.3rem;
max-width: 34rem;
color: rgba(255, 255, 255, 0.64);
line-height: 1.75;
}
.member-card-shell,
.empty-membership,
.empty-admin,
.admin-stat,
.info-panel {
border: 1px solid rgba(255, 255, 255, 0.12);
background: rgba(255, 255, 255, 0.055);
box-shadow: 0 28px 80px rgba(0, 0, 0, 0.28);
}
.member-card-shell,
.empty-membership {
display: flex;
align-items: center;
justify-content: center;
min-height: 26rem;
padding: 1.5rem;
}
.empty-membership,
.empty-admin {
color: rgba(255, 255, 255, 0.55);
}
.empty-admin {
padding: 2rem;
text-align: center;
}
.l484-card {
position: relative;
container-type: inline-size;
aspect-ratio: 1.586 / 1;
width: min(100%, 31rem);
overflow: hidden;
border: 1px solid rgba(74, 43, 18, 0.5);
border-radius: 8px;
background:
linear-gradient(90deg, rgba(46, 22, 9, 0.2), transparent 16%, rgba(255, 236, 190, 0.08) 46%, transparent 68%, rgba(47, 22, 9, 0.18)),
linear-gradient(180deg, rgba(255, 238, 203, 0.12), transparent 40%, rgba(55, 25, 8, 0.12)),
url('/images/pattern.jpg');
background-size:
auto,
auto,
cover;
background-position: center;
padding: clamp(1rem, 4vw, 1.6rem);
box-shadow:
0 28px 80px rgba(0, 0, 0, 0.42),
inset 0 1px rgba(255, 242, 210, 0.34),
inset 0 -1px rgba(53, 26, 12, 0.28);
}
.card-shine {
position: absolute;
inset: 0;
background:
linear-gradient(110deg, transparent 0 38%, rgba(255, 235, 190, 0.12) 48%, transparent 58%),
linear-gradient(180deg, rgba(41, 20, 8, 0.08), transparent 30%, rgba(43, 20, 8, 0.12));
opacity: 0.5;
mix-blend-mode: soft-light;
}
.card-reveal-stage {
position: relative;
width: 100%;
}
.card-reveal-stage.is-revealing {
isolation: isolate;
}
.card-reveal-stage.is-revealing .l484-card {
animation: cinematic-card-in 1500ms cubic-bezier(0.19, 1, 0.22, 1) 740ms both;
}
.card-reveal-stage.is-revealing::before,
.card-reveal-stage.is-revealing::after {
content: '';
position: absolute;
inset: -18%;
z-index: 6;
pointer-events: none;
opacity: 0;
}
.card-reveal-stage.is-revealing::before {
background:
linear-gradient(112deg, transparent 32%, rgba(255, 255, 240, 0.9) 46%, rgba(242, 169, 0, 0.58) 51%, transparent 66%);
filter: blur(0.18rem);
mix-blend-mode: screen;
transform: translate3d(-48%, 14%, 0) rotate(-9deg);
animation: cinematic-card-sweep 1300ms cubic-bezier(0.19, 1, 0.22, 1) 720ms both;
}
.card-reveal-stage.is-revealing::after {
background:
radial-gradient(ellipse at 50% 50%, rgba(242, 169, 0, 0.22), transparent 38%),
linear-gradient(112deg, transparent 38%, rgba(255, 210, 96, 0.2), transparent 62%);
filter: blur(1rem);
mix-blend-mode: screen;
transform: scale(0.96);
animation: cinematic-card-bloom 1600ms ease-out 520ms both;
}
.card-spinner {
position: absolute;
inset: 0;
z-index: 8;
display: grid;
place-items: center;
pointer-events: none;
animation: card-spinner-out 800ms ease 620ms forwards;
}
.card-spinner img {
width: clamp(2.4rem, 13vw, 4.2rem);
height: auto;
filter:
drop-shadow(0 0 0.6rem rgba(242, 169, 0, 0.62))
drop-shadow(0 0 2rem rgba(0, 0, 0, 0.8));
animation: card-logo-spin 900ms cubic-bezier(0.45, 0, 0.2, 1) infinite;
}
.burned-card-logo {
width: min(42%, 9.5rem);
height: auto;
opacity: 0.94;
filter:
brightness(0)
saturate(1)
sepia(1)
drop-shadow(0 1px 0 rgba(255, 224, 169, 0.12))
drop-shadow(0 -1px 0 rgba(18, 7, 2, 0.72))
drop-shadow(0 0 4px rgba(35, 12, 3, 0.5));
mix-blend-mode: multiply;
}
.card-status {
border: 1px solid rgba(41, 20, 9, 0.22);
border-radius: 999px;
padding: 0.35rem 0.55rem;
color: rgba(34, 18, 10, 0.78);
font-size: 0.62rem;
font-weight: 900;
letter-spacing: 0.16em;
text-transform: uppercase;
box-shadow:
inset 0 1px rgba(255, 236, 190, 0.22),
inset 0 -1px rgba(38, 16, 6, 0.16);
text-shadow:
0 1px rgba(255, 224, 168, 0.14),
0 -1px rgba(35, 14, 5, 0.34);
}
.card-status.is-pending {
border-color: rgba(55, 32, 12, 0.28);
color: rgba(63, 35, 10, 0.82);
}
.card-status.is-active {
border-color: rgba(26, 77, 42, 0.28);
color: rgba(18, 66, 34, 0.84);
}
.card-status.is-suspended {
border-color: rgba(96, 28, 24, 0.28);
color: rgba(82, 24, 18, 0.84);
}
.card-number {
margin: 0;
width: 100%;
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
font-size: clamp(1.35rem, 6.4cqw, 2.35rem);
font-weight: 800;
letter-spacing: clamp(0.008em, 0.12cqw, 0.045em);
line-height: 1;
text-align: center;
white-space: nowrap;
transform-origin: center;
color: rgba(28, 15, 8, 0.82);
text-shadow:
0 1px rgba(255, 224, 168, 0.13),
0 -1px rgba(20, 7, 2, 0.58),
0 0 3px rgba(39, 13, 3, 0.32);
mix-blend-mode: multiply;
}
.card-midline {
position: absolute;
left: clamp(1rem, 4vw, 1.6rem);
right: clamp(1rem, 4vw, 1.6rem);
top: 50%;
display: flex;
align-items: center;
justify-content: center;
transform: translateY(-46%);
}
.card-label {
color: rgba(39, 21, 12, 0.58);
font-size: 0.58rem;
font-weight: 900;
letter-spacing: 0.16em;
text-transform: uppercase;
}
.card-value {
margin-top: 0.25rem;
color: rgba(25, 14, 8, 0.84);
font-size: clamp(0.7rem, 2vw, 0.9rem);
font-weight: 800;
text-transform: uppercase;
text-shadow:
0 1px rgba(255, 224, 168, 0.12),
0 -1px rgba(20, 7, 2, 0.52),
0 0 3px rgba(39, 13, 3, 0.28);
mix-blend-mode: multiply;
}
.admin-hero {
margin-bottom: 1.5rem;
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
gap: 2rem;
align-items: end;
}
.admin-stat {
min-width: 6rem;
border: 1px solid rgba(255, 255, 255, 0.09);
border-radius: 6px;
background: rgba(255, 255, 255, 0.035);
padding: 0.78rem 0.9rem;
}
.admin-header {
position: sticky;
top: 0;
z-index: 120;
margin-right: calc(var(--admin-page-x) * -1);
margin-bottom: var(--admin-content-gap);
margin-left: calc(var(--admin-page-x) * -1);
display: grid;
grid-template-columns: auto minmax(0, 1fr) auto;
align-items: center;
gap: 1rem;
border-bottom: 1px solid rgba(255, 255, 255, 0.1);
background: rgba(5, 5, 5, 0.88);
padding: 0.65rem var(--admin-page-x);
backdrop-filter: blur(20px);
}
.admin-profile {
position: relative;
}
.admin-profile-button {
display: flex;
align-items: center;
gap: 0.75rem;
border: 1px solid rgba(255, 255, 255, 0.13);
border-radius: 8px;
background: rgba(255, 255, 255, 0.055);
padding: 0.55rem 0.7rem;
color: white;
text-align: left;
}
.admin-avatar {
display: grid;
width: 2.25rem;
height: 2.25rem;
place-items: center;
border: 1px solid rgba(255, 255, 255, 0.16);
border-radius: 999px;
color: white;
font-size: 0.86rem;
font-weight: 900;
}
.admin-profile-text {
display: grid;
gap: 0.1rem;
}
.admin-profile-text strong {
font-size: 0.82rem;
line-height: 1;
}
.admin-profile-text small {
color: rgba(255, 255, 255, 0.48);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
font-size: 0.68rem;
}
.admin-profile-menu {
position: absolute;
right: 0;
top: calc(100% + 0.55rem);
width: 15rem;
border: 1px solid rgba(255, 255, 255, 0.13);
border-radius: 8px;
background: rgba(8, 8, 8, 0.98);
padding: 0.55rem;
box-shadow: 0 24px 70px rgba(0, 0, 0, 0.5);
}
.admin-profile-menu p {
margin: 0;
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
padding: 0.65rem;
color: rgba(255, 255, 255, 0.52);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
font-size: 0.72rem;
}
.admin-profile-menu button {
width: 100%;
border: 0;
border-radius: 6px;
background: transparent;
padding: 0.75rem 0.65rem;
color: rgb(252, 165, 165);
font-size: 0.75rem;
font-weight: 900;
letter-spacing: 0.12em;
text-align: left;
text-transform: uppercase;
}
.admin-profile-menu button:hover {
background: rgba(255, 255, 255, 0.07);
}
.admin-stat strong,
.admin-stat span {
display: block;
}
.admin-stat strong {
font-size: 1rem;
}
.admin-stat span {
margin-top: 0.2rem;
color: rgba(255, 255, 255, 0.5);
font-size: 0.65rem;
font-weight: 800;
letter-spacing: 0.16em;
text-transform: uppercase;
}
.admin-tabbar {
display: grid;
grid-template-columns: repeat(5, minmax(0, 1fr));
gap: 0.5rem;
min-width: 0;
}
.mobile-admin-tabbar {
display: none;
}
.admin-tab {
position: relative;
display: grid;
grid-template-columns: auto minmax(0, 1fr) auto;
align-items: center;
gap: 0.55rem;
min-width: 0;
border: 1px solid transparent;
border-radius: 6px;
background: transparent;
padding: 0.72rem 0.78rem;
color: rgba(255, 255, 255, 0.56);
font-size: 0.7rem;
font-weight: 900;
letter-spacing: 0.13em;
text-align: left;
text-transform: uppercase;
transition: border-color 180ms ease, background 180ms ease, color 180ms ease;
}
.desktop-admin-tabbar .admin-tab {
gap: 0.42rem;
padding: 0.64rem 0.5rem;
font-size: 0.62rem;
letter-spacing: 0.1em;
}
.admin-tab svg {
width: 1rem;
height: 1rem;
fill: none;
stroke: currentColor;
stroke-linecap: round;
stroke-linejoin: round;
stroke-width: 1.8;
}
.admin-tab span {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.admin-tab strong {
display: grid;
min-width: 1.45rem;
height: 1.45rem;
place-items: center;
border-radius: 999px;
background: rgba(255, 255, 255, 0.08);
color: rgba(255, 255, 255, 0.72);
font-size: 0.62rem;
letter-spacing: 0;
}
.admin-tab:hover,
.admin-tab.active {
border-color: rgba(242, 169, 0, 0.35);
background: rgba(242, 169, 0, 0.12);
color: #fafafa;
}
.admin-tab.active strong {
background: #f2a900;
color: #050505;
}
.admin-panel-surface,
.admin-member-list,
.admin-member-grid,
.admin-payments-dashboard,
.admin-shell > .empty-admin {
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
background: rgba(255, 255, 255, 0.025);
box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28);
}
.admin-payments-dashboard {
display: grid;
gap: 1rem;
border-color: transparent;
background: transparent;
box-shadow: none;
}
.payment-metric-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 0.8rem;
}
.payment-metric,
.payment-chart-panel {
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
background:
radial-gradient(circle at 10% 0%, rgba(242, 169, 0, 0.1), transparent 16rem),
rgba(255, 255, 255, 0.025);
box-shadow: 0 24px 80px rgba(0, 0, 0, 0.24);
}
.payment-metric {
padding: 1rem;
}
.payment-metric span,
.payment-method-list span {
color: rgba(242, 169, 0, 0.82);
font-size: 0.64rem;
font-weight: 950;
letter-spacing: 0.16em;
text-transform: uppercase;
}
.payment-metric strong {
display: block;
margin-top: 0.55rem;
color: #fafafa;
font-size: clamp(1.35rem, 3vw, 2.2rem);
font-weight: 950;
line-height: 1;
}
.payment-metric p {
margin-top: 0.45rem;
color: rgba(255, 255, 255, 0.48);
font-size: 0.78rem;
}
.payment-dashboard-grid {
display: grid;
grid-template-columns: minmax(0, 1.35fr) minmax(18rem, 0.65fr);
gap: 1rem;
}
.payment-chart-panel {
padding: 1rem;
}
.payment-panel-heading {
display: flex;
align-items: end;
justify-content: space-between;
gap: 1rem;
margin-bottom: 1.1rem;
}
.payment-panel-heading h3 {
margin: 0;
color: #fafafa;
font-size: 1rem;
font-weight: 950;
letter-spacing: 0.02em;
text-transform: uppercase;
}
.payment-bar-chart {
display: grid;
grid-template-columns: repeat(7, minmax(0, 1fr));
align-items: end;
gap: 0.65rem;
min-height: 15rem;
border-top: 1px solid rgba(255, 255, 255, 0.08);
padding-top: 1rem;
}
.payment-day-bar {
display: grid;
grid-template-rows: 1fr auto;
gap: 0.55rem;
height: 100%;
min-height: 14rem;
}
.payment-day-bar span {
align-self: end;
min-height: 0.4rem;
border: 1px solid rgba(242, 169, 0, 0.28);
border-radius: 6px 6px 2px 2px;
background:
linear-gradient(180deg, #f2a900, rgba(242, 169, 0, 0.24)),
rgba(242, 169, 0, 0.1);
box-shadow: 0 12px 42px rgba(242, 169, 0, 0.18);
}
.payment-day-bar small,
.payment-method-list small,
.payment-table small {
color: rgba(255, 255, 255, 0.45);
font-size: 0.68rem;
font-weight: 800;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.payment-method-list {
display: grid;
gap: 1rem;
}
.payment-method-list article {
display: grid;
gap: 0.55rem;
}
.payment-method-list article > div:first-child {
display: flex;
align-items: baseline;
justify-content: space-between;
gap: 1rem;
}
.payment-method-list strong {
color: #fafafa;
font-size: 1.1rem;
font-weight: 950;
}
.payment-method-track {
height: 0.65rem;
overflow: hidden;
border-radius: 999px;
background: rgba(255, 255, 255, 0.08);
}
.payment-method-track i {
display: block;
height: 100%;
border-radius: inherit;
background: #f2a900;
}
.payment-table {
display: grid;
border-top: 1px solid rgba(255, 255, 255, 0.09);
}
.payment-table article {
display: grid;
grid-template-columns: 8rem 1fr auto 6rem;
gap: 1rem;
align-items: center;
border-bottom: 1px solid rgba(255, 255, 255, 0.09);
padding: 0.9rem 0;
}
.payment-table span {
color: rgba(242, 169, 0, 0.86);
font-size: 0.72rem;
font-weight: 950;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.payment-table p {
margin: 0;
color: rgba(255, 255, 255, 0.68);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
font-size: 0.78rem;
}
.payment-table strong {
color: #fafafa;
font-size: 0.9rem;
font-weight: 950;
}
.payment-choice-modal {
width: min(100%, 30rem);
}
.payment-choice-card {
display: grid;
width: 100%;
gap: 0.35rem;
border: 1px solid rgba(250, 250, 250, 0.18);
border-radius: 8px;
background: rgba(250, 250, 250, 0.055);
padding: 1rem;
color: #fafafa;
text-align: left;
transition: border-color 180ms ease, background 180ms ease, transform 180ms ease;
}
.payment-choice-card:hover:not(:disabled) {
border-color: rgba(250, 250, 250, 0.42);
background: rgba(250, 250, 250, 0.09);
transform: translateY(-1px);
}
.payment-choice-card.bitcoin {
border-color: rgba(242, 169, 0, 0.38);
background: rgba(242, 169, 0, 0.1);
}
.payment-choice-card:disabled {
cursor: not-allowed;
opacity: 0.48;
}
.payment-choice-card span,
.bitcoin-invoice-panel .section-kicker {
color: #f2a900;
font-size: 0.64rem;
font-weight: 950;
letter-spacing: 0.16em;
text-transform: uppercase;
}
.payment-choice-card strong,
.bitcoin-invoice-panel h3 {
color: #fafafa;
font-size: 1.25rem;
font-weight: 950;
line-height: 1.05;
text-transform: uppercase;
}
.payment-choice-card small,
.bitcoin-invoice-panel p {
color: rgba(255, 255, 255, 0.56);
font-size: 0.86rem;
line-height: 1.55;
}
.bitcoin-invoice-panel {
display: grid;
justify-items: center;
gap: 0.75rem;
border: 1px solid rgba(242, 169, 0, 0.26);
border-radius: 8px;
background:
radial-gradient(circle at 50% 0%, rgba(242, 169, 0, 0.18), transparent 16rem),
rgba(242, 169, 0, 0.08);
padding: 0.85rem;
}
.invoice-status-row,
.invoice-actions {
display: flex;
align-items: center;
width: 100%;
justify-content: center;
gap: 0.75rem;
}
.invoice-status-row {
justify-content: space-between;
}
.invoice-status-pill {
border: 1px solid rgba(96, 165, 250, 0.34);
border-radius: 999px;
background: rgba(96, 165, 250, 0.12);
padding: 0.42rem 0.62rem;
color: rgb(191, 219, 254);
font-size: 0.62rem;
font-weight: 950;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.invoice-status-pill.processing {
border-color: rgba(250, 204, 21, 0.36);
background: rgba(250, 204, 21, 0.12);
color: rgb(254, 240, 138);
}
.invoice-status-pill.settled {
border-color: rgba(52, 211, 153, 0.36);
background: rgba(52, 211, 153, 0.12);
color: rgb(167, 243, 208);
}
.invoice-status-pill.expired {
border-color: rgba(248, 113, 113, 0.36);
background: rgba(248, 113, 113, 0.12);
color: rgb(254, 202, 202);
}
.invoice-qr-wrap {
display: grid;
width: min(100%, 13.5rem);
aspect-ratio: 1;
place-items: center;
border: 1px solid rgba(255, 255, 255, 0.16);
border-radius: 8px;
background: #fafafa;
padding: 0.55rem;
}
.invoice-awaiting,
.invoice-success {
display: grid;
justify-items: center;
gap: 0.45rem;
text-align: center;
}
.invoice-awaiting {
grid-template-columns: auto auto;
align-items: center;
}
.invoice-awaiting span {
width: 0.58rem;
height: 0.58rem;
border-radius: 999px;
background: #f2a900;
box-shadow: 0 0 0 0 rgba(242, 169, 0, 0.5);
animation: invoice-pulse 1500ms ease-out infinite;
}
.invoice-awaiting strong,
.invoice-success strong {
color: #fafafa;
font-size: 1rem;
font-weight: 950;
letter-spacing: 0.1em;
text-transform: uppercase;
}
.invoice-success {
border: 1px solid rgba(52, 211, 153, 0.32);
border-radius: 8px;
background: rgba(52, 211, 153, 0.09);
padding: 1rem;
}
.invoice-success p {
color: rgba(255, 255, 255, 0.62);
font-size: 0.82rem;
line-height: 1.5;
}
.invoice-method-tabs {
display: grid;
width: 100%;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.35rem;
border: 1px solid rgba(255, 255, 255, 0.12);
border-radius: 8px;
background: rgba(0, 0, 0, 0.22);
padding: 0.3rem;
}
.invoice-method-tabs button {
border: 1px solid transparent;
border-radius: 6px;
background: transparent;
padding: 0.62rem 0.5rem;
color: rgba(255, 255, 255, 0.58);
font-size: 0.68rem;
font-weight: 950;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.invoice-method-tabs button.active {
border-color: rgba(242, 169, 0, 0.38);
background: rgba(242, 169, 0, 0.14);
color: #fafafa;
}
.invoice-qr-wrap img {
width: 100%;
height: 100%;
image-rendering: pixelated;
}
.invoice-qr-empty {
color: #111;
font-size: 0.8rem;
font-weight: 900;
text-transform: uppercase;
}
.invoice-data-box {
display: grid;
width: 100%;
gap: 0.35rem;
border: 1px solid rgba(255, 255, 255, 0.12);
border-radius: 8px;
background: rgba(0, 0, 0, 0.24);
padding: 0.75rem;
}
.invoice-data-box span {
color: rgba(242, 169, 0, 0.82);
font-size: 0.62rem;
font-weight: 950;
letter-spacing: 0.14em;
text-transform: uppercase;
}
.invoice-data-box code {
max-height: 6rem;
overflow: auto;
overflow-wrap: anywhere;
color: rgba(255, 255, 255, 0.76);
font-size: 0.72rem;
line-height: 1.45;
}
.invoice-actions {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.5rem;
}
.invoice-actions > * {
display: inline-flex;
width: 100%;
min-width: 0;
align-items: center;
justify-content: center;
text-align: center;
}
.invoice-help {
color: rgba(255, 255, 255, 0.52);
font-size: 0.72rem;
line-height: 1.55;
text-align: center;
}
.admin-toast {
position: fixed;
top: 5.2rem;
right: var(--admin-page-x);
z-index: 260;
max-width: min(24rem, calc(100vw - 2rem));
border: 1px solid rgba(52, 211, 153, 0.32);
border-radius: 8px;
background:
linear-gradient(135deg, rgba(52, 211, 153, 0.14), transparent 60%),
rgba(8, 16, 12, 0.96);
padding: 0.85rem 1rem;
color: rgb(209, 250, 229);
font-size: 0.84rem;
font-weight: 800;
line-height: 1.4;
box-shadow: 0 20px 70px rgba(0, 0, 0, 0.42);
backdrop-filter: blur(18px);
}
.admin-toast.error {
border-color: rgba(248, 113, 113, 0.4);
background:
linear-gradient(135deg, rgba(248, 113, 113, 0.15), transparent 60%),
rgba(20, 8, 8, 0.96);
color: rgb(254, 202, 202);
}
.admin-section-heading {
display: flex;
align-items: end;
justify-content: space-between;
gap: 1rem;
border-bottom: 1px solid rgba(255, 255, 255, 0.09);
padding: 1.2rem;
}
.admin-section-heading h3 {
margin: 0;
font-size: 1.2rem;
font-weight: 950;
line-height: 1;
text-transform: uppercase;
}
.admin-member-list {
display: grid;
}
.admin-member-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 1.1rem;
justify-content: stretch;
border-color: transparent;
background: transparent;
box-shadow: none;
}
.admin-member-tile {
position: relative;
display: grid;
gap: 0.85rem;
align-content: start;
width: 100%;
min-width: 0;
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
background: rgba(255, 255, 255, 0.025);
padding: 0.9rem;
}
.admin-tile-actions {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.55rem;
width: 100%;
}
.admin-tile-actions > button {
width: 100%;
min-width: 0;
min-height: 3.15rem;
border-color: rgba(250, 250, 250, 0.36);
background: transparent;
color: #fafafa;
padding: 0.78rem 0.9rem;
}
.admin-tile-actions > button:only-child {
grid-column: 1 / -1;
}
.admin-tile-actions > .primary-action {
border-color: rgba(242, 169, 0, 0.78);
background: #f2a900;
color: #080808;
}
.admin-tile-actions > .secondary-action:hover {
border-color: rgba(250, 250, 250, 0.62);
background: rgba(250, 250, 250, 0.08);
color: #fafafa;
transform: translateY(-1px);
}
.admin-scan-field {
grid-column: 1 / -1;
}
.admin-scan-field input {
width: 100%;
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: rgba(255, 255, 255, 0.06);
padding: 0.78rem 0.9rem;
color: white;
font-size: 0.9rem;
outline: none;
}
.admin-scan-field input:focus {
border-color: rgba(242, 169, 0, 0.76);
}
.admin-member-row {
position: relative;
display: grid;
grid-template-columns: minmax(18rem, 24rem) minmax(0, 1fr) auto;
gap: 1.2rem;
align-items: start;
padding: 1.2rem;
}
.admin-member-row + .admin-member-row {
border-top: 1px solid rgba(255, 255, 255, 0.09);
}
.admin-card-item {
display: flex;
flex-direction: column;
gap: 1rem;
}
.admin-wood-card {
width: 100%;
box-shadow:
0 18px 54px rgba(0, 0, 0, 0.36),
inset 0 1px rgba(255, 242, 210, 0.34),
inset 0 -1px rgba(53, 26, 12, 0.28);
}
.admin-wood-card .card-number {
font-size: clamp(0.95rem, 5.35cqw, 1.8rem);
letter-spacing: clamp(0.004em, 0.08cqw, 0.028em);
}
.admin-wood-card .card-label {
font-size: 0.5rem;
}
.admin-wood-card .card-value {
font-size: clamp(0.62rem, 1.3vw, 0.78rem);
}
.admin-card-button {
display: block;
width: 100%;
border: 0;
background: transparent;
padding: 0;
text-align: left;
cursor: pointer;
}
.admin-card-meta {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
color: rgba(255, 255, 255, 0.55);
font-size: 0.86rem;
}
.admin-member-details {
display: grid;
gap: 0.85rem;
min-width: 0;
}
.admin-member-title {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 1rem;
}
.admin-member-title p {
margin: 0;
color: #fafafa;
font-size: 1rem;
font-weight: 900;
line-height: 1.1;
text-transform: uppercase;
}
.admin-member-title span {
display: block;
margin-top: 0.22rem;
color: rgba(255, 255, 255, 0.42);
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
font-size: 0.72rem;
}
.admin-member-title strong {
border: 1px solid rgba(242, 169, 0, 0.26);
border-radius: 999px;
background: rgba(242, 169, 0, 0.1);
padding: 0.34rem 0.55rem;
color: rgba(242, 169, 0, 0.92);
font-size: 0.62rem;
font-weight: 950;
letter-spacing: 0.13em;
text-transform: uppercase;
white-space: nowrap;
}
.admin-member-meta {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.35rem 1rem;
color: rgba(255, 255, 255, 0.54);
font-size: 0.82rem;
}
.admin-member-meta p {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.admin-actions {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 0.55rem;
}
.admin-actions.two-actions {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.admin-actions > button {
width: 100%;
min-width: 0;
}
.admin-card-issue {
display: grid;
gap: 0.7rem;
border-top: 1px solid rgba(255, 255, 255, 0.08);
padding-top: 0.85rem;
}
.admin-ops-panel {
display: grid;
gap: 0.8rem;
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
background: rgba(255, 255, 255, 0.035);
padding: 0.9rem;
}
.admin-ops-actions {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
gap: 0.5rem;
}
.admin-ops-actions > button {
width: 100%;
min-width: 0;
}
.access-log-list {
display: grid;
gap: 0;
}
.access-log-row {
display: grid;
grid-template-columns: 5rem 1fr auto;
gap: 1rem;
align-items: center;
border-bottom: 1px solid rgba(255, 255, 255, 0.12);
padding: 0.95rem 1.1rem;
}
.access-log-row span {
font-size: 0.72rem;
font-weight: 950;
letter-spacing: 0.16em;
text-transform: uppercase;
}
.access-log-row p,
.access-log-row small {
margin: 0;
color: rgba(255, 255, 255, 0.58);
}
.access-log-row p {
padding-inline: 0.25rem;
}
.empty-admin {
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
background: rgba(255, 255, 255, 0.035);
padding: 2.2rem;
color: rgba(255, 255, 255, 0.55);
font-size: 0.95rem;
font-weight: 800;
text-align: center;
}
.icon-danger-action {
display: grid;
min-height: 3.2rem;
place-items: center;
border: 1px solid rgba(255, 154, 154, 0.36);
border-radius: 8px;
background: rgba(255, 255, 255, 0.045);
color: rgb(255, 176, 176);
transition:
border-color 180ms ease,
background 180ms ease,
color 180ms ease,
transform 180ms ease;
}
.icon-danger-action:hover {
border-color: rgba(255, 154, 154, 0.64);
background: rgba(255, 81, 81, 0.1);
color: rgb(255, 205, 205);
transform: translateY(-1px);
}
.icon-danger-action svg {
width: 1.15rem;
height: 1.15rem;
fill: none;
stroke: currentColor;
stroke-linecap: round;
stroke-linejoin: round;
stroke-width: 1.8;
}
@media (max-width: 1180px) {
.admin-member-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
}
@media (max-width: 900px) {
.admin-member-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
@media (max-width: 720px) {
.admin-member-grid {
grid-template-columns: 1fr;
}
}
.admin-card-meta .delete-member {
opacity: 0;
pointer-events: none;
transform: translateY(-2px);
}
.admin-member-row > .delete-member {
opacity: 0;
pointer-events: none;
transform: translateY(-2px);
}
.admin-card-item:hover .delete-member,
.admin-card-item:focus-within .delete-member,
.admin-member-row:hover > .delete-member,
.admin-member-row:focus-within > .delete-member {
opacity: 1;
pointer-events: auto;
transform: translateY(0);
}
.modal-backdrop {
position: fixed;
inset: 0;
z-index: 500;
display: flex;
align-items: center;
justify-content: center;
overflow-y: auto;
background: rgba(0, 0, 0, 0.78);
padding: 1rem;
}
.signup-modal {
position: relative;
z-index: 1;
display: flex;
flex-direction: column;
width: min(100%, 44rem);
max-height: calc(100svh - 2rem);
overflow: hidden;
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: rgba(8, 8, 8, 0.96);
box-shadow: 0 40px 140px rgba(0, 0, 0, 0.7);
}
.signup-modal.card-modal {
width: min(100%, 27rem);
}
.signup-modal.card-modal > .flex:first-child {
padding: 1.5rem;
}
.signup-modal.card-modal > .flex:first-child > div {
max-width: 24rem;
}
.signup-modal.card-modal .modal-body {
padding: 1.5rem;
}
.signup-modal.card-modal .card-modal-content,
.signup-modal.card-modal .modal-footer-actions {
width: 100%;
max-width: 24rem;
margin-inline: auto;
}
.signup-modal.card-modal .modal-footer {
padding: 1.5rem;
}
.signup-modal.card-modal .l484-card {
width: 100%;
}
.signup-modal.card-modal .card-number {
font-size: clamp(1.35rem, 7.4cqw, 1.55rem);
letter-spacing: 0.02em;
}
.backup-modal {
position: relative;
z-index: 1;
width: min(100%, 34rem);
overflow: hidden;
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: rgba(8, 8, 8, 0.98);
box-shadow: 0 40px 140px rgba(0, 0, 0, 0.7);
}
.agreement-modal {
position: relative;
z-index: 1;
width: min(100%, 40rem);
max-height: calc(100svh - 3rem);
overflow: hidden;
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: #080808;
box-shadow: 0 40px 140px rgba(0, 0, 0, 0.7);
}
.agreement-body {
display: grid;
max-height: min(30rem, calc(100svh - 15rem));
gap: 1rem;
overflow-y: auto;
padding: 1rem;
}
.agreement-info {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.65rem;
border: 1px solid rgba(255, 255, 255, 0.1);
border-radius: 8px;
background: #101010;
padding: 1rem;
}
.agreement-info p {
display: grid;
gap: 0.2rem;
margin: 0;
color: rgba(255, 255, 255, 0.86);
overflow-wrap: anywhere;
}
.agreement-info span {
color: rgba(255, 255, 255, 0.48);
font-size: 0.68rem;
font-weight: 900;
letter-spacing: 0.14em;
text-transform: uppercase;
}
.agreement-signature {
display: flex;
min-height: 8rem;
align-items: center;
justify-content: center;
border: 1px solid rgba(242, 169, 0, 0.28);
border-radius: 8px;
background: #080808;
padding: 1rem;
color: rgba(255, 255, 255, 0.52);
}
.agreement-signature img {
max-height: 9rem;
max-width: 100%;
object-fit: contain;
}
@media (min-width: 900px) {
.agreement-modal {
width: 38rem;
}
}
@media (max-width: 820px) {
.agreement-info {
grid-template-columns: 1fr;
}
}
.modal-body {
flex: 1 1 auto;
min-height: 0;
max-height: min(34rem, calc(100svh - 16rem));
overflow-y: auto;
padding: 1.25rem;
}
.step-row {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 1rem 1.25rem 0;
}
.step-row span {
display: grid;
width: 2rem;
height: 2rem;
place-items: center;
border: 1px solid rgba(255, 255, 255, 0.18);
border-radius: 999px;
color: rgba(255, 255, 255, 0.55);
font-size: 0.8rem;
font-weight: 900;
}
.step-row span.active {
border-color: rgba(242, 169, 0, 0.86);
color: #f2a900;
}
.step-row i {
height: 1px;
flex: 1;
background: rgba(255, 255, 255, 0.14);
}
.field-label {
display: block;
color: rgba(255, 255, 255, 0.72);
font-size: 0.78rem;
font-weight: 900;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.optional-label {
color: rgba(255, 255, 255, 0.42);
font-weight: 800;
}
.field-input {
margin-top: 0.5rem;
width: 100%;
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: rgba(255, 255, 255, 0.06);
padding: 0.9rem 1rem;
color: white;
font-size: 1rem;
outline: none;
}
.field-input:focus {
border-color: rgba(242, 169, 0, 0.76);
box-shadow: 0 0 0 3px rgba(242, 169, 0, 0.12);
}
.info-panel,
.covenant-box {
border: 1px solid rgba(255, 255, 255, 0.12);
border-radius: 8px;
padding: 1rem;
}
.membership-price-panel {
border: 1px solid rgba(242, 169, 0, 0.28);
border-radius: 8px;
background:
linear-gradient(135deg, rgba(242, 169, 0, 0.11), transparent 38%),
rgba(255, 255, 255, 0.055);
padding: 1rem;
}
.membership-price-row {
display: flex;
align-items: baseline;
gap: 0.65rem;
margin-top: 0.65rem;
}
.membership-price-row strong {
color: #fafafa;
font-size: clamp(2.25rem, 11vw, 3.8rem);
font-weight: 950;
line-height: 0.9;
}
.membership-price-row span {
color: rgba(255, 255, 255, 0.58);
font-size: 0.82rem;
font-weight: 900;
letter-spacing: 0.16em;
text-transform: uppercase;
}
.membership-btc-row {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 0.45rem 0.75rem;
margin-top: 0.8rem;
border-top: 1px solid rgba(255, 255, 255, 0.1);
padding-top: 0.8rem;
}
.membership-btc-row small {
color: rgba(255, 255, 255, 0.5);
font-size: 0.74rem;
font-weight: 800;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.membership-pickup-card {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.9rem;
align-items: center;
border: 1px solid rgba(247, 147, 26, 0.42);
border-radius: 8px;
background:
radial-gradient(circle at 0% 50%, rgba(247, 147, 26, 0.22), transparent 52%),
linear-gradient(135deg, rgba(247, 147, 26, 0.15), rgba(247, 147, 26, 0.055));
padding: 1rem;
box-shadow:
inset 0 1px rgba(255, 213, 139, 0.16),
0 1.4rem 3rem rgba(0, 0, 0, 0.22);
}
.membership-pickup-card p {
margin: 0;
color: rgba(255, 244, 226, 0.9);
font-size: 1rem;
font-weight: 750;
line-height: 1.55;
}
.membership-pickup-icon {
display: grid;
width: 3rem;
aspect-ratio: 1;
place-items: center;
border: 1px solid rgba(247, 147, 26, 0.42);
border-radius: 8px;
background: rgba(247, 147, 26, 0.16);
}
.membership-pickup-icon img {
width: 1.55rem;
height: 1.9rem;
object-fit: contain;
filter:
invert(63%)
sepia(96%)
saturate(1188%)
hue-rotate(348deg)
brightness(104%)
contrast(94%)
drop-shadow(0 0 0.75rem rgba(247, 147, 26, 0.28));
}
.signature-box {
overflow: hidden;
border: 1px solid rgba(242, 169, 0, 0.28);
border-radius: 8px;
background:
linear-gradient(rgba(255, 255, 255, 0.055) 1px, transparent 1px),
radial-gradient(circle at 80% 12%, rgba(242, 169, 0, 0.12), transparent 28%),
#080808;
background-size: 100% 2.6rem;
box-shadow:
inset 0 0 0 1px rgba(255, 255, 255, 0.08),
0 18px 44px rgba(0, 0, 0, 0.26);
}
.signature-box.signed {
border-color: rgba(16, 185, 129, 0.55);
}
.signature-canvas {
display: block;
width: 100%;
height: 12.5rem;
cursor: crosshair;
touch-action: none;
}
.signature-clear {
border: 1px solid rgba(255, 255, 255, 0.14);
border-radius: 8px;
background: rgba(255, 255, 255, 0.06);
padding: 0.45rem 0.65rem;
color: rgba(255, 255, 255, 0.66);
font-size: 0.68rem;
font-weight: 900;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.covenant-box {
background: rgba(255, 255, 255, 0.05);
}
.covenant-box h3 {
margin-bottom: 0.8rem;
color: white;
font-weight: 900;
}
.covenant-box ol {
list-style: decimal;
padding-left: 1.2rem;
color: rgba(255, 255, 255, 0.68);
line-height: 1.65;
}
@media (max-width: 820px) {
.modal-backdrop {
padding: 0.5rem;
}
.signup-modal,
.backup-modal,
.agreement-modal {
max-height: calc(100svh - 1rem);
}
.modal-footer {
grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
padding: 0.75rem;
}
.modal-body {
max-height: calc(100svh - 13rem);
}
.member-button {
padding: 0.62rem 0.7rem;
font-size: 0.62rem;
letter-spacing: 0.08em;
}
.l484-card {
padding: 1rem;
}
.signup-modal.card-modal .card-midline {
left: 0.95rem;
right: 0.95rem;
transform: translateY(-44%);
}
.card-number {
letter-spacing: 0.03em;
}
.admin-stat {
min-width: auto;
padding: 0.65rem 0.4rem;
}
.admin-shell {
--admin-page-x: 0.75rem;
padding: 0 var(--admin-page-x) 6.25rem;
}
.admin-header {
position: relative;
z-index: 20;
grid-template-columns: auto auto;
justify-content: space-between;
margin-bottom: 1.25rem;
margin-inline: calc(var(--admin-page-x) * -1);
padding: 0.8rem 0.75rem;
}
.admin-profile-text {
display: none;
}
.desktop-admin-tabbar {
display: none;
}
.mobile-admin-tabbar {
position: fixed;
left: 0;
right: 0;
bottom: 0;
z-index: 240;
display: grid;
grid-template-columns: repeat(5, minmax(0, 1fr));
gap: 4px;
border-top: 1px solid rgba(255, 255, 255, 0.13);
background: rgba(5, 5, 5, 0.96);
padding: 0.45rem 0.35rem calc(0.45rem + env(safe-area-inset-bottom));
box-shadow: 0 -18px 54px rgba(0, 0, 0, 0.62);
backdrop-filter: blur(22px);
}
.mobile-admin-tab {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.25rem;
min-height: 3.65rem;
border-radius: 8px;
padding: 0.5rem 0.15rem;
font-size: 0.46rem;
letter-spacing: 0.055em;
text-align: center;
}
.mobile-admin-tab svg {
width: 1.12rem;
height: 1.12rem;
}
.mobile-admin-tab span {
max-width: 100%;
font-size: 0.5rem;
}
.mobile-admin-tab strong {
position: absolute;
top: 0.25rem;
right: 0.45rem;
min-width: 1rem;
height: 1rem;
font-size: 0.5rem;
}
.admin-panel-surface,
.admin-member-list,
.admin-member-grid,
.admin-shell > .empty-admin {
width: 100%;
}
.admin-toast {
inset: auto 0.75rem calc(5.25rem + env(safe-area-inset-bottom));
max-width: none;
}
.payment-metric-grid,
.payment-dashboard-grid {
grid-template-columns: 1fr;
}
.payment-metric {
padding: 0.9rem;
}
.payment-metric strong {
font-size: 1.6rem;
}
.payment-chart-panel {
padding: 0.85rem;
}
.payment-panel-heading {
display: grid;
gap: 0.25rem;
margin-bottom: 0.85rem;
}
.payment-bar-chart {
gap: 0.42rem;
min-height: 9rem;
padding-top: 0.75rem;
}
.payment-day-bar {
min-height: 8rem;
gap: 0.4rem;
}
.payment-day-bar small {
font-size: 0.56rem;
letter-spacing: 0.03em;
}
.payment-table article {
grid-template-columns: 1fr auto;
gap: 0.35rem 0.8rem;
padding: 0.85rem 0.1rem;
}
.payment-table article p {
grid-column: 1 / -1;
order: 3;
overflow-wrap: anywhere;
}
.payment-table article small {
justify-self: end;
}
.invoice-actions {
grid-template-columns: 1fr;
}
.admin-member-row {
grid-template-columns: 1fr;
gap: 1rem;
padding: 0.85rem;
}
.admin-member-row > .delete-member {
position: static;
opacity: 1;
pointer-events: auto;
transform: none;
}
.admin-member-meta,
.admin-actions,
.admin-actions.two-actions {
grid-template-columns: 1fr;
}
.access-log-row {
grid-template-columns: 1fr;
gap: 0.25rem;
padding: 0.9rem;
}
.modal-footer-actions {
display: grid;
width: 100%;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.5rem;
}
.modal-footer-actions > button {
width: 100%;
min-width: 0;
padding-inline: 0.5rem;
text-align: center;
}
}
@keyframes bg-cinema {
0% {
opacity: 0;
filter: saturate(0.65) contrast(1.24) blur(14px);
transform: scale(1.13) translate3d(0, 0, 0);
}
22% {
opacity: 1;
filter: saturate(1.04) contrast(1.12) blur(0);
}
100% {
opacity: 1;
filter: saturate(1.08) contrast(1.08) blur(0);
transform: scale(1.02) translate3d(-1.2%, -0.8%, 0);
}
}
@keyframes invoice-pulse {
0% {
box-shadow: 0 0 0 0 rgba(242, 169, 0, 0.48);
}
100% {
box-shadow: 0 0 0 0.75rem rgba(242, 169, 0, 0);
}
}
@keyframes copy-in {
0% {
opacity: 0;
transform: translate3d(0, 34px, 0);
}
100% {
opacity: 1;
transform: translate3d(0, 0, 0);
}
}
@keyframes cinematic-word-in {
0% {
opacity: 0;
clip-path: inset(0 100% 0 0);
filter: blur(0.5rem) saturate(0.72);
transform: translate3d(0, 1.1rem, 0) scale(0.985);
}
42% {
opacity: 1;
filter: blur(0.08rem) saturate(1.04);
}
100% {
opacity: 1;
clip-path: inset(0 0 0 0);
filter: blur(0) saturate(1);
transform: translate3d(0, 0, 0) scale(1);
}
}
@keyframes benefits-cue-in {
0% {
opacity: 0;
transform: translate3d(0, 0.7rem, 0);
}
100% {
opacity: 1;
transform: translate3d(0, 0, 0);
}
}
@keyframes swipe-up-cue {
0%,
100% {
opacity: 1;
transform: translateY(0);
}
50% {
opacity: 0.5;
transform: translateY(-1.25rem);
}
}
@keyframes mouse-wheel-cue {
0% {
opacity: 0;
transform: translateY(0);
}
38% {
opacity: 1;
}
100% {
opacity: 0;
transform: translateY(0.62rem);
}
}
@keyframes rise-in {
0% {
opacity: 0;
transform: translate3d(0, -16px, 0);
}
100% {
opacity: 1;
transform: translate3d(0, 0, 0);
}
}
@keyframes grain-shift {
0% {
transform: translate3d(-1%, -1%, 0);
}
100% {
transform: translate3d(1%, 1%, 0);
}
}
@keyframes scanline {
0% {
opacity: 0;
transform: translateY(0);
}
18% {
opacity: 1;
}
100% {
opacity: 0;
transform: translateY(100svh);
}
}
@keyframes card-logo-spin {
0% {
opacity: 0;
transform: scale(0.82) rotate(0deg);
}
18% {
opacity: 1;
}
100% {
opacity: 1;
transform: scale(1) rotate(360deg);
}
}
@keyframes card-spinner-out {
0% {
opacity: 1;
transform: scale(1);
}
100% {
opacity: 0;
transform: scale(0.9);
}
}
@keyframes cinematic-card-in {
0% {
opacity: 0;
filter: blur(0.9rem) saturate(0.75) contrast(1.18);
clip-path: inset(50% 0 50% 0);
transform: scale(0.965) translateY(0.45rem);
}
38% {
opacity: 1;
clip-path: inset(0 0 0 0);
}
100% {
opacity: 1;
filter: blur(0) saturate(1) contrast(1);
clip-path: inset(0 0 0 0);
transform: scale(1) translateY(0);
}
}
@keyframes cinematic-card-sweep {
0% {
opacity: 0;
transform: translate3d(-48%, 14%, 0) rotate(-9deg);
}
16% {
opacity: 0.88;
}
64% {
opacity: 0.62;
}
100% {
opacity: 0;
transform: translate3d(48%, -14%, 0) rotate(-9deg);
}
}
@keyframes cinematic-card-bloom {
0% {
opacity: 0;
transform: scale(0.96);
}
32% {
opacity: 0.85;
}
100% {
opacity: 0;
transform: scale(1.08);
}
}
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 1ms !important;
animation-iteration-count: 1 !important;
scroll-behavior: auto !important;
}
}