From 7bbc85937bdc0410499a0fed367553f2f6e024da Mon Sep 17 00:00:00 2001 From: sairaj mote Date: Fri, 6 Jan 2023 02:42:54 +0530 Subject: [PATCH] New UI --- css/main.css | 569 +++++------ css/main.min.css | 2 +- css/main.scss | 557 +++++----- index.html | 1911 +++++++++++++++++------------------ scripts/btcOperator.js | 747 ++++++++++++++ scripts/components.js | 21 +- scripts/floBlockchainAPI.js | 45 +- scripts/floCloudAPI.js | 88 +- scripts/floCrypto.js | 62 +- scripts/floDapps.js | 73 +- scripts/floTokenAPI.js | 18 +- scripts/lib.js | 1512 ++++++++++++++++----------- 12 files changed, 3309 insertions(+), 2296 deletions(-) create mode 100644 scripts/btcOperator.js diff --git a/css/main.css b/css/main.css index f4f597f..a580e61 100644 --- a/css/main.css +++ b/css/main.css @@ -2,7 +2,12 @@ padding: 0; margin: 0; box-sizing: border-box; - font-family: "Roboto", sans-serif; + font-family: "Inter", sans-serif; +} +*:focus-visible { + outline: var(--accent-color) solid medium; + outline-offset: 0; + transition: outline-offset 0.3s; } :root { @@ -15,17 +20,20 @@ body { } body { - --accent-color: #4d77ff; - --text-color: 20, 20, 20; - --foreground-color: 252, 253, 255; - --background-color: 241, 243, 248; - --danger-color: rgb(255, 75, 75); + --accent-color: #234ebf; + --accent-color-rgb: 35, 78, 191; + --blue-accent-1: #f5f8ff; + --blue-accent-2: #f2f6ff; + --text-color: 58, 58, 58; + --foreground-color: 255, 255, 255; + --background-color: 243, 245, 250; + --danger-color: #ff6161; --green: #1cad59; --yellow: rgb(220, 165, 0); scrollbar-width: thin; scrollbar-gutter: stable; color: rgba(var(--text-color), 1); - background-color: rgba(var(--background-color), 1); + background-color: rgba(var(--foreground-color), 1); transition: background-color 0.3s; position: relative; display: flex; @@ -34,6 +42,9 @@ body { body[data-theme=dark] { --accent-color: #a0b6ff; + --accent-color-rgb: 160, 182, 255; + --blue-accent-1: #f5f8ff10; + --blue-accent-2: #f2f6ff10; --text-color: 220, 220, 220; --foreground-color: 27, 28, 29; --background-color: 21, 22, 22; @@ -66,18 +77,8 @@ a { text-decoration: none; color: var(--accent-color); } -a:focus-visible { - box-shadow: 0 0 0 0.1rem rgba(var(--text-color), 1) inset; -} - -a.button { - padding: 0.4rem 0.6rem; - border-radius: 0.3rem; - font-size: 0.9rem; - font-weight: 500; - color: inherit; -} +.button, button { -webkit-user-select: none; -moz-user-select: none; @@ -93,20 +94,21 @@ button { font-weight: 500; white-space: nowrap; padding: 0.8rem; - border-radius: 0.3rem; + border-radius: 0.5rem; justify-content: center; color: inherit; + min-width: -webkit-max-content; + min-width: -moz-max-content; + min-width: max-content; } -button:focus-visible { - outline: var(--accent-color) solid medium; -} +.button:not(:disabled), button:not(:disabled) { cursor: pointer; } .button { color: var(--accent-color); - background-color: rgba(var(--text-color), 0.06); + background-color: var(--blue-accent-1); } .button .icon { fill: var(--accent-color); @@ -152,18 +154,6 @@ button:disabled { opacity: 0.5; } -a:-webkit-any-link:focus-visible { - outline: rgba(var(--text-color), 1) 0.1rem solid; -} - -a:-moz-any-link:focus-visible { - outline: rgba(var(--text-color), 1) 0.1rem solid; -} - -a:any-link:focus-visible { - outline: rgba(var(--text-color), 1) 0.1rem solid; -} - details summary { display: flex; -webkit-user-select: none; @@ -172,7 +162,6 @@ details summary { cursor: pointer; align-items: center; justify-content: space-between; - color: var(--accent-color); } details[open] summary { @@ -192,18 +181,8 @@ sm-textarea button .icon { fill: var(--accent-color); } -sm-button { - --padding: 0.8rem; -} -sm-button[variant=primary] .icon { - fill: rgba(var(--background-color), 1); -} -sm-button[disabled] .icon { - fill: rgba(var(--text-color), 0.6); -} -sm-button.danger { - --background: var(--danger-color); - color: rgba(var(--background-color), 1); +sm-copy { + font-size: 0.9rem; } sm-spinner { @@ -225,26 +204,26 @@ sm-option { } sm-chips { - --gap: 0; - background-color: rgba(var(--text-color), 0.06); - border-radius: 0.3rem; - padding: 0.3rem; + --gap: 0.3rem; } sm-chip { - font-size: 0.8rem; - --border-radius: 0.2rem; + position: relative; + font-size: 0.9rem; + --border-radius: 0.5rem; + --padding: 0.5rem 0.8rem; + --background: rgba(var(--text-color), 0.06); -webkit-user-select: none; -moz-user-select: none; user-select: none; + font-weight: 500; +} +sm-chip[selected] { + --background: var(--accent-color); + color: rgba(var(--foreground-color), 1); } -sm-copy { - font-size: 0.9rem; -} - -ul, -ol { +ul { list-style: none; } @@ -440,6 +419,10 @@ ol li::before { margin-right: 0.5rem; } +.margin-right-auto { + margin-right: auto; +} + .margin-left-0-5 { margin-left: 0.5rem; } @@ -593,16 +576,16 @@ ol li::before { height: 100%; } .page__header { + position: -webkit-sticky; + position: sticky; + top: 0; display: flex; - justify-content: space-between; + flex-direction: column; + align-items: flex-start; + gap: 1rem; margin-bottom: 1.5rem; - min-height: 5rem; -} -.page__header .grid { - margin-top: auto; -} -.page__header h1 { - font-size: 2rem; + background-color: rgba(var(--foreground-color), 1); + z-index: 1; } #confirmation_popup, @@ -729,13 +712,36 @@ ol li::before { #main_header { display: grid; - gap: 1.5rem; - padding: 1rem 1rem; + gap: 1rem; + padding: 1rem; align-items: center; - grid-template-columns: minmax(0, 1fr) auto; + grid-template-columns: 1fr auto auto auto; min-height: 4rem; } +#user_profile_button { + background-color: var(--blue-accent-1); + border-radius: 2rem; + font-size: 0.8rem; + padding: 0.6rem 0.8rem; + font-weight: 700; +} + +#notifications_wrapper { + position: relative; +} + +#notifications_panel { + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 10; + background-color: rgba(var(--foreground-color), 1); + padding: 1rem; +} + .logged-in-user-id { background-color: rgba(var(--text-color), 0.06); max-width: -webkit-fit-content; @@ -753,61 +759,11 @@ ol li::before { height: 100%; width: 100%; transition: background-color 0.3s; - background-color: rgba(var(--background-color), 1); } #main_card.nav-hidden .inner-page { grid-area: 2/1/3/-1; } -#main_navbar { - display: flex; - background-color: rgba(var(--foreground-color), 0.8); -} -#main_navbar ul { - display: flex; - height: 100%; - width: 100%; -} -#main_navbar ul li { - width: 100%; -} - -.nav-item { - position: relative; - display: flex; - flex: 1; - width: 100%; - flex-direction: column; - align-items: center; - justify-content: center; - padding: 0.5rem 0.3rem; - color: var(--text-color); - font-size: 0.8rem; - font-weight: 500; - gap: 0.5rem; -} -.nav-item .icon { - transition: transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); -} -.nav-item__title { - transition: opacity 0.2s, transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); -} -.nav-item--active { - color: var(--accent-color); -} -.nav-item--active .icon { - fill: var(--accent-color); -} -.nav-item__indicator { - position: absolute; - bottom: 0; - width: 2rem; - height: 0.3rem; - background: var(--accent-color); - border-radius: 1rem 1rem 0 0; - z-index: 1; -} - .badge { display: flex; align-items: center; @@ -864,9 +820,45 @@ ol li::before { } #home { + position: relative; + display: grid; + padding: 0; + gap: 3rem; + overflow-y: visible; + align-content: initial; +} +#home > * { + align-content: flex-start; +} + +#wallet_section { position: relative; display: flex; flex-direction: column; + height: 100%; + gap: 1.5rem; + background-color: rgba(var(--accent-color-rgb), 0.02); +} +#wallet_section sm-chips { + display: flex; + justify-content: center; +} +#wallet_section sm-chip::part(chip) { + width: 8rem; + justify-content: center; +} +#wallet_section > * { + width: 100%; +} +#wallet_section::before { + content: ""; + position: absolute; + top: -10vmax; + left: 0; + width: 100%; + height: 10vmax; + background-color: inherit; + pointer-events: none; } #user, @@ -896,41 +888,30 @@ ol li::before { #wallet_cards_wrapper { display: grid; - gap: 0.5rem; - grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr)); - align-items: flex-start; + grid-template-columns: 6rem 1fr; + background-color: rgba(var(--text-color), 0.06); + border-radius: 0.5rem; + padding: 0 0.2rem; +} +#wallet_cards_wrapper sm-input { + --background: transparent; +} +#wallet_cards_wrapper sm-select { + margin: 0.2rem 0; + --background: rgba(var(--foreground-color), 1); +} +#wallet_cards_wrapper sm-select[open] { + z-index: 10; } .balance-card { - display: grid; - overflow: hidden; - border-radius: 0.8rem; - background-color: rgba(var(--foreground-color), 1); + background-color: rgba(var(--accent-color-rgb), 0.06); + border-radius: 0.5rem; + padding: 0.8rem; + font-size: 0.9rem; } .balance-card > * { - padding: 1rem; - gap: 1.5rem; -} -.balance-card > :last-child:not(:only-child) { - border-top: thin solid rgba(var(--text-color), 0.2); -} -.balance-card .asset-icon { - height: 2.5rem; - width: 2.5rem; - padding: 0.6rem; - border-radius: 1.1rem; - margin-right: 0.8rem; - fill: rgba(var(--background-color), 1); -} -.balance-card .asset-icon--rupee { - background-color: var(--green); -} -.balance-card .asset-icon--flo { - fill: white; - background-color: #4d77ff; -} -.balance-card .asset-icon--btc { - background-color: rgb(255, 173, 8); + font-weight: 500; } #rupee_balance span:first-of-type, @@ -945,9 +926,11 @@ ol li::before { } .actions-wrapper { - display: grid; + display: flex; gap: 0.5rem; - grid-template-columns: repeat(auto-fill, minmax(4rem, 1fr)); +} +.actions-wrapper > * { + flex: 1; } .wallet-action, @@ -955,12 +938,17 @@ ol li::before { position: relative; color: inherit; font-weight: 500; + font-size: 0.9rem; } .wallet-action .icon:first-of-type, .integrated-action-button .icon:first-of-type { - height: 1.5rem; - width: 1.5rem; + height: 3rem; + width: 3rem; + padding: 0.95rem; + overflow: visible; fill: var(--accent-color); + border-radius: 2rem; + background-color: var(--blue-accent-2); } .wallet-action .badge, .integrated-action-button .badge { @@ -969,20 +957,13 @@ ol li::before { } .wallet-action { + gap: 0.5rem; flex-direction: column; - text-align: center; align-items: center; font-size: 0.8rem; white-space: initial; - padding: 0.8rem; - border: solid thin rgba(var(--text-color), 0.1); border-radius: 0.5rem; -} -.wallet-action:hover { - border: solid thin rgba(var(--text-color), 0.5); -} -.wallet-action .icon { - margin-bottom: 0.8rem; + padding: 0; } .integrated-action-button { @@ -992,8 +973,8 @@ ol li::before { .integrated-action-button .icon:first-of-type { margin-right: 1rem; } -.integrated-action-button .icon:last-of-type { - margin-left: 0.5rem; +.integrated-action-button span:last-of-type { + font-size: 1rem; } .cashier-status { @@ -1049,53 +1030,48 @@ ol li::before { position: relative; } +#recent_contacts { + gap: 0; +} + #saved_ids_list { display: grid; - gap: 0.5rem; + gap: 1rem; grid-template-columns: minmax(0, 1fr); margin-bottom: 1.5rem; } .saved-id { + align-items: center; grid-template-columns: auto 1fr; - gap: 0 0.8rem; - border-radius: 0.5rem; - padding: 0.5rem; + gap: 0 1rem; + padding: 0.5rem 0; -webkit-user-select: none; -moz-user-select: none; user-select: none; - background-color: rgba(var(--foreground-color), 1); + border-radius: 0.5rem; } .saved-id.highlight { box-shadow: 0 0 0.1rem 0.1rem var(--accent-color) inset; } .saved-id .edit-saved { - grid-area: 1/1/3/2; padding: 0.3rem; position: relative; } -.saved-id .edit-saved .icon { - position: absolute; - right: 0; - bottom: 0; - border-radius: 0.5rem; - padding: 0.2rem; - background-color: rgba(var(--background-color), 1); -} .saved-id__initials { display: flex; align-items: center; justify-content: center; - height: 2.4rem; - width: 2.4rem; + height: 2.5rem; + width: 2.5rem; font-size: 1.2rem; text-transform: uppercase; - color: rgba(var(--background-color), 1); + color: var(--accent-color); font-weight: 700; line-height: 1; - background-color: var(--accent-color); - justify-self: flex-start; + background-color: rgba(var(--text-color), 0.03); border-radius: 2rem; + grid-area: 1/1/3/2; } .saved-id__title { align-self: flex-end; @@ -1107,6 +1083,11 @@ ol li::before { .saved-id__flo-id { font-size: 0.8rem; } +.saved-id__copy { + padding: 0.3rem 0.5rem; + border-radius: 0.3rem; + background-color: rgba(var(--text-color), 0.03); +} #saved_ids_tip { background-color: rgba(var(--text-color), 0.03); @@ -1187,25 +1168,15 @@ ol li::before { font-size: 0.8rem; } -#history .page__header { - margin-bottom: 0; -} - -#history_applied_filters_wrapper { - position: -webkit-sticky; - position: sticky; - top: 0; +#history_applied_filters { padding: 0.2rem 0 0.5rem 0; - background-color: rgba(var(--background-color), 1); - z-index: 1; - transition: background-color 0.3s; } .applied-filter { display: flex; align-items: center; padding: 0.5rem 0.6rem 0.5rem 0.8rem; - border-radius: 1rem; + border-radius: 0.5rem; border: solid thin rgba(var(--text-color), 0.2); text-transform: uppercase; font-size: 0.8rem; @@ -1219,6 +1190,17 @@ ol li::before { margin-left: 0.3rem; } +fieldset { + border: none; + padding: 0; + margin: 0; +} +fieldset legend { + font-size: 0.8rem; + font-weight: 500; + margin-bottom: 0.5rem; +} + .category-chip { display: inline-flex; align-items: center; @@ -1228,11 +1210,6 @@ ol li::before { font-size: 0.8rem; border: solid thin rgba(var(--text-color), 0.2); font-weight: 700; - letter-spacing: 0.08em; - text-transform: uppercase; -} -.category-chip:focus { - outline: solid var(--accent-color); } .category-chip input { display: none; @@ -1266,6 +1243,7 @@ ol li::before { display: grid; gap: 2rem; margin-top: 1.5rem; + padding-bottom: 3rem; } .transaction { @@ -1276,16 +1254,16 @@ ol li::before { .transaction__amount { white-space: nowrap; } -.transaction.sent .icon { - fill: rgba(var(--text-color), 0.8); +.transaction.sent .icon--tx-type { + fill: var(--danger-color); } .transaction.sent .transaction__amount { - color: rgba(var(--text-color), 0.8); + color: var(--danger-color); } .transaction.sent .transaction__amount::before { content: "- "; } -.transaction.received .icon { +.transaction.received .icon--tx-type { fill: var(--green); } .transaction.received .transaction__amount { @@ -1295,14 +1273,30 @@ ol li::before { content: "+ "; } .transaction__icon { - display: flex; + position: relative; + grid-area: icon; + display: grid; align-items: center; justify-content: center; - grid-area: 1/1/3/2; width: 2.5rem; height: 2.5rem; background-color: rgba(var(--text-color), 0.03); border-radius: 2rem; + grid-area: 1/1/3/2; +} +.transaction__icon > * { + grid-area: 1/1; +} +.transaction__icon .icon--tx-type { + position: absolute; + background-color: inherit; + right: -0.3rem; + bottom: -0.3rem; + border-radius: 1rem; + padding: 0.2rem; + height: 1.5rem; + width: 1.5rem; + border: solid medium rgba(var(--foreground-color), 1); } .transaction__receiver { font-weight: 500; @@ -1313,7 +1307,7 @@ ol li::before { } .transaction__amount { font-size: 1rem; - font-weight: 700; + font-weight: 500; grid-area: 1/3/3/4; } @@ -1323,13 +1317,10 @@ ol li::before { align-items: center; grid-template-areas: "icon time amount" "icon receiver receiver" "icon txid txid"; } -.btc-tx:not(:last-of-type) { - padding-bottom: 1rem; -} .btc-tx__amount { white-space: nowrap; } -.btc-tx.out .icon { +.btc-tx.out .icon--tx-type { fill: var(--danger-color); } .btc-tx.out .btc-tx__amount { @@ -1338,7 +1329,7 @@ ol li::before { .btc-tx.out .btc-tx__amount::before { content: "- "; } -.btc-tx.in .icon { +.btc-tx.in .icon--tx-type { fill: var(--green); } .btc-tx.in .btc-tx__amount { @@ -1354,8 +1345,9 @@ ol li::before { fill: var(--yellow); } .btc-tx__icon { + position: relative; grid-area: icon; - display: flex; + display: grid; align-items: center; justify-content: center; width: 2.5rem; @@ -1363,23 +1355,37 @@ ol li::before { background-color: rgba(var(--text-color), 0.03); border-radius: 2rem; } +.btc-tx__icon > * { + grid-area: 1/1; +} +.btc-tx__icon .icon--tx-type { + position: absolute; + background-color: inherit; + right: -0.3rem; + bottom: -0.3rem; + border-radius: 1rem; + padding: 0.2rem; + height: 1.5rem; + width: 1.5rem; + border: solid medium rgba(var(--foreground-color), 1); +} .btc-tx__receiver { grid-area: receiver; font-weight: 500; } .btc-tx__time { grid-area: time; - font-size: 0.9rem; + font-size: 0.8rem; color: rgba(var(--text-color), 0.8); } .btc-tx__amount { grid-area: amount; font-size: 1rem; - font-weight: 700; + font-weight: 500; } .btc-tx__id { grid-area: txid; - font-size: 0.9rem; + font-size: 0.8rem; color: rgba(var(--text-color), 0.8); } .btc-tx .unconfirmed-wrapper { @@ -1411,12 +1417,6 @@ ol li::before { background-color: rgba(var(--foreground-color), 1); } -#add_address_button { - border-radius: 0.5rem; - background-color: transparent; - border: solid 0.1rem var(--accent-color); -} - .user-action-result__icon { justify-self: center; height: 4rem; @@ -1561,6 +1561,9 @@ ol li::before { color: var(--accent-color); background-color: rgba(var(--foreground-color), 1); } +.payment-request--pending { + padding: 0; +} .wallet-request { display: grid; @@ -1652,13 +1655,14 @@ ol li::before { } @media screen and (max-width: 40rem) { - .inner-page { - padding-bottom: 7rem; + #home { + padding-bottom: 3rem; } - #main_navbar.hide-away { - bottom: 0; - left: 0; - right: 0; + #home > * { + padding: 0 1rem; + } + .integrated-action-button .icon:last-of-type { + margin-left: auto; } .nav-item--active .icon { transform: translateY(50%); @@ -1670,6 +1674,9 @@ ol li::before { .integrated-action-button .icon:last-of-type { margin-left: auto; } + .hide-on-mobile { + display: none; + } } @media screen and (min-width: 40rem) { sm-popup { @@ -1682,51 +1689,39 @@ ol li::before { align-items: center; justify-content: center; } - #main_card { - display: grid; - grid-template-columns: 10rem 1fr; - grid-template-rows: auto 1fr; - grid-template-areas: "header header" "navbar content"; + .inner-page { + padding: 0 14vw; } #main_header { - grid-area: header; - padding: 1rem 1.5rem; - background-color: rgba(var(--foreground-color), 1); - } - #main_navbar { - height: 100%; - grid-area: navbar; - } - #main_navbar ul { - flex-direction: column; - gap: 0.3rem; - padding: 0.3rem; - } - .nav-item { - padding: 1rem; - padding-right: 2rem; - border-radius: 0.5rem; - flex-direction: row; - justify-content: start; - gap: 0.5rem; - font-size: 0.9rem; - opacity: 0.8; - } - .nav-item--active { - opacity: 1; - } - .nav-item__indicator { - width: 0.25rem; - height: 50%; - left: 0; - border-radius: 0 1rem 1rem 0; - bottom: auto; + padding: 1.5rem 3vw; } .card { padding: 1.5rem; } - .balance-card > * { - padding: 1.5rem; + #home { + grid-template-columns: 26rem 1fr; + gap: 4vw; + padding-right: 3vw; + } + #profile_popup { + --width: 32rem; + } + #notifications_panel { + position: absolute; + top: 100%; + left: auto; + bottom: auto; + right: 0; + border-radius: 0.5rem; + z-index: 10; + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1); + border: solid 1px rgba(var(--text-color), 0.1); + background-color: rgba(var(--foreground-color), 1); + width: max(24rem, 100%); + } + #wallet_section { + padding: 0 3vw; + grid-row: 1/3; } #contact > * { padding: 1rem 12vw; @@ -1735,10 +1730,16 @@ ol li::before { padding: 0.5rem 12vw; } #saved_ids_list { - grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr)); + gap: 1.5rem; + grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr)); } - .inner-page { - padding: 1.5rem 14vw; + .hide-on-desktop { + display: none; + } +} +@media screen and (min-width: 68rem) { + #home { + grid-template-columns: 26rem 1fr 1fr; } } @media (any-hover: hover) { @@ -1753,20 +1754,24 @@ ol li::before { ::-webkit-scrollbar-thumb:hover { background: rgba(var(--text-color), 0.5); } - .interact:not([disabled]) { + .button--primary:not([disabled]), +.button--danger:not([disabled]) { + transition: filter 0.3s; + } + .button--primary:not([disabled]):hover, +.button--danger:not([disabled]):hover { + filter: brightness(1.3); + } + .interact:not([disabled]), +button:not([disabled], .button--primary, .button--danger), +.button:not([disabled], .button--primary, .button--danger) { transition: background-color 0.3s; } - .interact:not([disabled]):hover { + .interact:not([disabled]):hover, +button:not([disabled], .button--primary, .button--danger):hover, +.button:not([disabled], .button--primary, .button--danger):hover { background-color: rgba(var(--text-color), 0.06); } - button:not([disabled]), -.button:not([disabled]) { - transition: background-color 0.3s, filter 0.3s; - } - button:not([disabled]):hover, -.button:not([disabled]):hover { - filter: contrast(2); - } } @supports (overflow: overlay) { body { diff --git a/css/main.min.css b/css/main.min.css index 3dbbbc4..c2a9c2d 100644 --- a/css/main.min.css +++ b/css/main.min.css @@ -1 +1 @@ -*{padding:0;margin:0;box-sizing:border-box;font-family:"Roboto",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%}body{--accent-color: #4d77ff;--text-color: 20, 20, 20;--foreground-color: 252, 253, 255;--background-color: 241, 243, 248;--danger-color: rgb(255, 75, 75);--green: #1cad59;--yellow: rgb(220, 165, 0);scrollbar-width:thin;scrollbar-gutter:stable;color:rgba(var(--text-color), 1);background-color:rgba(var(--background-color), 1);transition:background-color .3s;position:relative;display:flex;flex-direction:column}body[data-theme=dark]{--accent-color: #a0b6ff;--text-color: 220, 220, 220;--foreground-color: 27, 28, 29;--background-color: 21, 22, 22;--danger-color: rgb(255, 106, 106);--green: #00e676;--yellow: rgb(255, 213, 5)}body[data-theme=dark] sm-popup::part(popup){background-color:rgba(var(--foreground-color), 1)}p,strong{font-size:.9rem;max-width:65ch;line-height:1.7;color:rgba(var(--text-color), 0.9)}.warning{line-height:normal;padding:1rem;background-color:khaki;border-radius:.5rem;font-weight:500;color:rgba(0,0,0,.7)}a{text-decoration:none;color:var(--accent-color)}a:focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}a.button{padding:.4rem .6rem;border-radius:.3rem;font-size:.9rem;font-weight:500;color:inherit}button{-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;display:inline-flex;border:none;background-color:rgba(0,0,0,0);overflow:hidden;-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;font-size:.9rem;font-weight:500;white-space:nowrap;padding:.8rem;border-radius:.3rem;justify-content:center;color:inherit}button:focus-visible{outline:var(--accent-color) solid medium}button:not(:disabled){cursor:pointer}.button{color:var(--accent-color);background-color:rgba(var(--text-color), 0.06)}.button .icon{fill:var(--accent-color)}.button--primary,.button--danger{color:rgba(var(--background-color), 1) !important}.button--primary .icon,.button--danger .icon{fill:rgba(var(--background-color), 1)}.button--primary{width:100%;background-color:var(--accent-color)}.button--danger{background-color:var(--danger-color)}.button--small{padding:.4rem .6rem}.cta{text-transform:uppercase;font-size:.8rem;font-weight:700;letter-spacing:.05em;padding:.8rem 1rem}.icon{width:1.2rem;height:1.2rem;fill:rgba(var(--text-color), 0.8);flex-shrink:0}.icon-only{padding:.5rem;border-radius:.3rem}button:disabled{opacity:.5}a:-webkit-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:-moz-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}details summary{display:flex;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;align-items:center;justify-content:space-between;color:var(--accent-color)}details[open] summary{margin-bottom:1rem}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-input,sm-textarea{--border-radius: 0.3rem;--background-color: rgba(var(--foreground-color), 1)}sm-input button .icon,sm-textarea button .icon{fill:var(--accent-color)}sm-button{--padding: 0.8rem}sm-button[variant=primary] .icon{fill:rgba(var(--background-color), 1)}sm-button[disabled] .icon{fill:rgba(var(--text-color), 0.6)}sm-button.danger{--background: var(--danger-color);color:rgba(var(--background-color), 1)}sm-spinner{--size: 1rem;--stroke-width: 0.1rem}sm-form{--gap: 1rem}sm-select{--padding: 0.8rem;font-size:.9rem}sm-option{font-size:.9rem}sm-chips{--gap: 0;background-color:rgba(var(--text-color), 0.06);border-radius:.3rem;padding:.3rem}sm-chip{font-size:.8rem;--border-radius: 0.2rem;-webkit-user-select:none;-moz-user-select:none;user-select:none}sm-copy{font-size:.9rem}ul,ol{list-style:none}ol{counter-reset:item}ol li{position:relative;display:flex;align-items:flex-start;counter-increment:item}ol li:not(:last-of-type){padding-bottom:1.5rem}ol li:not(:last-of-type)::after{content:"";position:absolute;width:.1rem;height:calc(100% - 2.2rem);background:var(--accent-color);margin-left:.7rem;margin-top:2rem}ol li::before{content:counter(item);display:flex;align-items:center;justify-content:center;text-align:center;font-size:.8rem;font-weight:500;margin-top:.15rem;margin-right:1rem;line-height:1;width:1.5rem;height:1.5rem;border-radius:100%;flex-shrink:0;color:rgba(var(--text-color), 0.8);background:rgba(var(--text-color), 0.1)}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.wrap-around{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.full-bleed{grid-column:1/-1}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.sticky{position:-webkit-sticky;position:sticky}.top-0{top:0}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.grid{display:grid}.flow-column{grid-auto-flow:column}.gap-0-3{gap:.3rem}.gap-0-5{gap:.5rem}.gap-1{gap:1rem}.gap-1-5{gap:1.5rem}.gap-2{gap:2rem}.gap-3{gap:3rem}.text-align-right{text-align:right}.align-start{align-content:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.text-center{text-align:center}.justify-start{justify-items:start}.justify-center{justify-content:center}.justify-items-center{justify-items:center}.justify-right{margin-left:auto}.align-self-center{align-self:center}.align-self-end{align-self:end}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.flex-direction-column{flex-direction:column}.space-between{justify-content:space-between}.margin-right-0-3{margin-right:.3rem}.margin-right-0-5{margin-right:.5rem}.margin-left-0-5{margin-left:.5rem}.margin-left-auto{margin-left:auto}.margin-top-1{margin-top:1rem}.margin-top-1-5{margin-top:1.5rem}.margin-bottom-0-5{margin-bottom:.5rem}.margin-bottom-1{margin-bottom:1rem}.margin-bottom-1-5{margin-bottom:1.5rem}.margin-bottom-2{margin-bottom:2rem}.padding-0-3{padding:.3rem}.padding-0-5{padding:.5rem}.padding-1{padding:1rem}.padding-inline-0-5{padding-inline:.5rem}.padding-inline-1{padding-inline:1rem}.padding-block-0-5{padding-block:.5rem}.padding-block-1{padding-block:1rem}.border-radius-0-3{border-radius:.3rem}.border-radius-0-5{border-radius:.5rem}.font-0-9{font-size:.9rem}.w-100{width:100%}.h-100{height:100%}.label{font-size:.8rem;color:rgba(var(--text-color), 0.8);font-weight:500;margin-bottom:.2rem}.button--primary .ripple,.button--danger .ripple{background:radial-gradient(circle, rgba(var(--background-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%)}.ripple{height:8rem;width:8rem;position:absolute;border-radius:50%;transform:scale(0);background:radial-gradient(circle, rgba(var(--text-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%);pointer-events:none}.interact{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0)}.empty-state{display:grid;width:100%;padding:1.5rem 0}.observe-empty-state:empty{display:none !important}.observe-empty-state:not(:empty)+.empty-state{display:none !important}.bullet-point{display:flex;align-items:center;justify-content:center;margin:0 .8ch}.bullet-point::after{content:"";height:.4ch;width:.4ch;border-radius:.5em;background-color:var(--accent-color)}.icon-button{padding:.6rem;border-radius:.8rem;background-color:rgba(var(--text-color), 0.1);height:-webkit-max-content;height:-moz-max-content;height:max-content}.icon-button .icon{fill:var(--accent-color)}.page{height:100%}.page__header{display:flex;justify-content:space-between;margin-bottom:1.5rem;min-height:5rem}.page__header .grid{margin-top:auto}.page__header h1{font-size:2rem}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{margin-bottom:.5rem}#confirmation_popup .flex,#prompt_popup .flex{margin-top:1rem}#prompt_message{margin-bottom:1.5rem}.popup__header{position:relative;display:grid;gap:.5rem;width:100%;padding:0 1.5rem 0 .5rem;align-items:center;grid-template-columns:auto 1fr}.popup__header>*{grid-row:1}.popup__header h3,.popup__header h4{grid-column:1/-1;justify-self:center;align-self:center}.popup__header__close{grid-column:1}.flo-icon{margin-right:.3rem;height:1.5rem;width:1.5rem}#secondary_pages{display:flex;flex-direction:column;width:100%}#secondary_pages header{padding:1.5rem}#secondary_pages .inner-page{height:100%}#landing>section{justify-content:center;justify-items:center;align-items:center;text-align:center;padding:8vw 0}#landing h1{font-size:clamp(2rem,5vw,5rem)}#sign_in,#sign_up{justify-content:center;align-items:center}#sign_in sm-form,#sign_up sm-form{margin:2rem 0}#sign_in{display:grid;align-content:center;padding:0;justify-items:center}#sign_in .illustration{height:auto;background-color:#4d77ff;border-radius:1rem;width:min(24rem,100%)}#sign_in section{width:min(24rem,100%);background-color:rgba(var(--foreground-color), 1);padding:max(1.5rem,2vw);border-radius:.5rem;margin-top:-1.6rem}#sign_up .h2{margin-bottom:.5rem}#sign_up .card{margin:1.5rem 0}#sign_up h5{color:rgba(var(--text-color), 0.8)}#flo_id_warning{padding-bottom:1.5rem;border-bottom:thin solid rgba(var(--text-color), 0.3)}#flo_id_warning .icon{height:4rem;width:4rem;padding:1rem;background-color:#ffc107;border-radius:3rem;fill:rgba(0,0,0,.8);margin-bottom:1.5rem}#main_header{display:grid;gap:1.5rem;padding:1rem 1rem;align-items:center;grid-template-columns:minmax(0, 1fr) auto;min-height:4rem}.logged-in-user-id{background-color:rgba(var(--text-color), 0.06);max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content;padding:.4rem .8rem .4rem .5rem;border-radius:2rem;font-weight:500}#main_card{position:relative;display:flex;flex-direction:column;height:100%;width:100%;transition:background-color .3s;background-color:rgba(var(--background-color), 1)}#main_card.nav-hidden .inner-page{grid-area:2/1/3/-1}#main_navbar{display:flex;background-color:rgba(var(--foreground-color), 0.8)}#main_navbar ul{display:flex;height:100%;width:100%}#main_navbar ul li{width:100%}.nav-item{position:relative;display:flex;flex:1;width:100%;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .3rem;color:var(--text-color);font-size:.8rem;font-weight:500;gap:.5rem}.nav-item .icon{transition:transform .2s cubic-bezier(0.175, 0.885, 0.32, 1.275)}.nav-item__title{transition:opacity .2s,transform .2s cubic-bezier(0.175, 0.885, 0.32, 1.275)}.nav-item--active{color:var(--accent-color)}.nav-item--active .icon{fill:var(--accent-color)}.nav-item__indicator{position:absolute;bottom:0;width:2rem;height:.3rem;background:var(--accent-color);border-radius:1rem 1rem 0 0;z-index:1}.badge{display:flex;align-items:center;justify-content:center;content:attr(data-notifications);position:absolute;top:0;right:0;font-size:.8rem;padding:.3rem;background:var(--danger-color);color:rgba(var(--background-color), 1);aspect-ratio:1/1;font-weight:700;border-radius:.3rem;margin:.3rem}.inner-page{display:flex;flex-direction:column;padding:0 1rem;flex:1;align-content:start;overflow-y:auto}.password-field label{display:flex;justify-content:center}.password-field label input:checked~.visible{display:none}.password-field label input:not(:checked)~.invisible{display:none}.multi-state-button{display:grid;text-align:center;align-items:center;justify-items:center}.multi-state-button>*{grid-area:1/1/2/2}.multi-state-button button{z-index:1}.scrolling-wrapper{overflow-y:auto}#home{position:relative;display:flex;flex-direction:column}#user,#cashier{position:relative;padding-bottom:1rem;align-content:flex-start}.swap-input{display:grid;grid-template-columns:6rem 1fr;background-color:rgba(var(--text-color), 0.06);border-radius:.5rem;padding:0 .2rem}.swap-input sm-input{--background: transparent}.swap-input sm-select{margin:.2rem 0;--background: rgba(var(--foreground-color), 1)}.swap-input sm-select[open]{z-index:10}#wallet_cards_wrapper{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit, minmax(20rem, 1fr));align-items:flex-start}.balance-card{display:grid;overflow:hidden;border-radius:.8rem;background-color:rgba(var(--foreground-color), 1)}.balance-card>*{padding:1rem;gap:1.5rem}.balance-card>:last-child:not(:only-child){border-top:thin solid rgba(var(--text-color), 0.2)}.balance-card .asset-icon{height:2.5rem;width:2.5rem;padding:.6rem;border-radius:1.1rem;margin-right:.8rem;fill:rgba(var(--background-color), 1)}.balance-card .asset-icon--rupee{background-color:var(--green)}.balance-card .asset-icon--flo{fill:#fff;background-color:#4d77ff}.balance-card .asset-icon--btc{background-color:#ffad08}#rupee_balance span:first-of-type,#flo_balance span:first-of-type,#btc_balance span:first-of-type{font-size:1.5rem}#rupee_balance span:nth-of-type(2),#flo_balance span:nth-of-type(2),#btc_balance span:nth-of-type(2){font-size:1rem}.actions-wrapper{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill, minmax(4rem, 1fr))}.wallet-action,.integrated-action-button{position:relative;color:inherit;font-weight:500}.wallet-action .icon:first-of-type,.integrated-action-button .icon:first-of-type{height:1.5rem;width:1.5rem;fill:var(--accent-color)}.wallet-action .badge,.integrated-action-button .badge{left:0;right:auto}.wallet-action{flex-direction:column;text-align:center;align-items:center;font-size:.8rem;white-space:initial;padding:.8rem;border:solid thin rgba(var(--text-color), 0.1);border-radius:.5rem}.wallet-action:hover{border:solid thin rgba(var(--text-color), 0.5)}.wallet-action .icon{margin-bottom:.8rem}.integrated-action-button{padding:0;justify-content:flex-start}.integrated-action-button .icon:first-of-type{margin-right:1rem}.integrated-action-button .icon:last-of-type{margin-left:.5rem}.cashier-status{font-size:.9rem;padding:1rem 1.2rem;border-radius:1rem;background-color:rgba(240,230,140,.8);color:rgba(0,0,0,.8)}.cashier-status .icon{fill:rgba(0,0,0,.8)}#topup_wallet__qr_code{background-color:rgba(var(--text-color), 0.03);border-radius:.5rem;height:10rem;justify-self:flex-start;width:10rem}#topup_wallet__qr_code svg{width:100%;height:100%;fill:rgba(var(--text-color), 1)}#cashier_status{font-size:.9rem;padding:1rem 1.2rem;border-radius:1rem;background-color:rgba(240,230,140,.8);color:rgba(0,0,0,.8)}#cashier_status .icon{fill:rgba(0,0,0,.8)}.remove-card-wrapper{min-height:2rem}.receiver-card{display:grid;gap:.5rem;padding:.5rem 0;border:none}.receiver-card:not(:last-of-type){border-bottom:solid thin rgba(var(--text-color), 0.3)}#contacts{position:relative}#saved_ids_list{display:grid;gap:.5rem;grid-template-columns:minmax(0, 1fr);margin-bottom:1.5rem}.saved-id{grid-template-columns:auto 1fr;gap:0 .8rem;border-radius:.5rem;padding:.5rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;background-color:rgba(var(--foreground-color), 1)}.saved-id.highlight{box-shadow:0 0 .1rem .1rem var(--accent-color) inset}.saved-id .edit-saved{grid-area:1/1/3/2;padding:.3rem;position:relative}.saved-id .edit-saved .icon{position:absolute;right:0;bottom:0;border-radius:.5rem;padding:.2rem;background-color:rgba(var(--background-color), 1)}.saved-id__initials{display:flex;align-items:center;justify-content:center;height:2.4rem;width:2.4rem;font-size:1.2rem;text-transform:uppercase;color:rgba(var(--background-color), 1);font-weight:700;line-height:1;background-color:var(--accent-color);justify-self:flex-start;border-radius:2rem}.saved-id__title{align-self:flex-end;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.saved-id__flo-id{font-size:.8rem}#saved_ids_tip{background-color:rgba(var(--text-color), 0.03);border-radius:2rem;padding:.5rem .8rem .5rem .5rem}.card{background-color:rgba(var(--foreground-color), 1);border-radius:.5rem;padding:1rem}#contact{display:grid;grid-template-rows:auto 1fr auto;padding:0;height:100%}#contact>*{padding:1rem 1.5rem}#contact>:first-child{padding-top:0}#contact>:last-child{padding:.5rem 1.5rem;border-top:solid thin rgba(var(--text-color), 0.2)}#contact>:last-child button{padding:.8rem 2rem;border-radius:1rem;color:var(--accent-color);background-color:rgba(var(--text-color), 0.03)}#contact__transactions{position:relative;display:grid;gap:.5rem;overflow-y:auto;flex:1;padding:0 max(1rem,8vw) 1rem max(1rem,8vw);align-content:flex-start}#contact__transactions sm-spinner{position:absolute;justify-self:center;align-self:center}.transaction-message{background-color:rgba(var(--text-color), 0.06);padding:1rem;border-radius:.5rem;justify-self:flex-start;border-radius:0 1rem 1rem 1rem;gap:.5rem}.transaction-message.received{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}.transaction-message.received+.transaction-message.received{border-radius:1rem}.transaction-message.sent{margin-left:auto;justify-self:flex-end;border-radius:1rem 1rem 0 1rem;text-align:right}.transaction-message__amount{font-size:1.2rem}.transaction-message__time{opacity:.8;font-size:.8rem}#history .page__header{margin-bottom:0}#history_applied_filters_wrapper{position:-webkit-sticky;position:sticky;top:0;padding:.2rem 0 .5rem 0;background-color:rgba(var(--background-color), 1);z-index:1;transition:background-color .3s}.applied-filter{display:flex;align-items:center;padding:.5rem .6rem .5rem .8rem;border-radius:1rem;border:solid thin rgba(var(--text-color), 0.2);text-transform:uppercase;font-size:.8rem;font-weight:500;letter-spacing:.08em}.applied-filter button{padding:.6rem}.applied-filter .icon{margin-left:.3rem}.category-chip{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .5rem;border-radius:.3rem;font-size:.8rem;border:solid thin rgba(var(--text-color), 0.2);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.category-chip:focus{outline:solid var(--accent-color)}.category-chip input{display:none}.category-chip span{transition:transform .2s;transform:translateX(-0.8rem)}.category-chip .icon{opacity:0;transition:opacity .2s,transform .2s;margin-right:.3rem;fill:var(--accent-color);transform:translateX(0.5rem)}.category-chip input:checked~.icon{opacity:1;transform:translateX(0)}.category-chip input:checked~span{color:var(--accent-color);transform:translateX(0)}#wallet_history_wrapper{margin-top:1.5rem;padding-bottom:3rem}#payments_history{display:grid;gap:2rem;margin-top:1.5rem}.transaction{grid-template-columns:auto 1fr auto;gap:.5rem 1rem;align-items:center}.transaction__amount{white-space:nowrap}.transaction.sent .icon{fill:rgba(var(--text-color), 0.8)}.transaction.sent .transaction__amount{color:rgba(var(--text-color), 0.8)}.transaction.sent .transaction__amount::before{content:"- "}.transaction.received .icon{fill:var(--green)}.transaction.received .transaction__amount{color:var(--green)}.transaction.received .transaction__amount::before{content:"+ "}.transaction__icon{display:flex;align-items:center;justify-content:center;grid-area:1/1/3/2;width:2.5rem;height:2.5rem;background-color:rgba(var(--text-color), 0.03);border-radius:2rem}.transaction__receiver{font-weight:500}.transaction__time{font-size:.8rem;color:rgba(var(--text-color), 0.8)}.transaction__amount{font-size:1rem;font-weight:700;grid-area:1/3/3/4}.btc-tx{grid-template-columns:auto 1fr auto;gap:.5rem 1rem;align-items:center;grid-template-areas:"icon time amount" "icon receiver receiver" "icon txid txid"}.btc-tx:not(:last-of-type){padding-bottom:1rem}.btc-tx__amount{white-space:nowrap}.btc-tx.out .icon{fill:var(--danger-color)}.btc-tx.out .btc-tx__amount{color:var(--danger-color)}.btc-tx.out .btc-tx__amount::before{content:"- "}.btc-tx.in .icon{fill:var(--green)}.btc-tx.in .btc-tx__amount{color:var(--green)}.btc-tx.in .btc-tx__amount::before{content:"+ "}.btc-tx.unconfirmed-tx{grid-template-areas:"icon time amount" "icon receiver receiver" "icon txid txid" "icon unconfirmed unconfirmed" "icon badge badge"}.btc-tx.unconfirmed-tx .icon{fill:var(--yellow)}.btc-tx__icon{grid-area:icon;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background-color:rgba(var(--text-color), 0.03);border-radius:2rem}.btc-tx__receiver{grid-area:receiver;font-weight:500}.btc-tx__time{grid-area:time;font-size:.9rem;color:rgba(var(--text-color), 0.8)}.btc-tx__amount{grid-area:amount;font-size:1rem;font-weight:700}.btc-tx__id{grid-area:txid;font-size:.9rem;color:rgba(var(--text-color), 0.8)}.btc-tx .unconfirmed-wrapper{grid-area:unconfirmed;padding:.5rem 0}.btc-tx .pending-badge{grid-area:badge;font-size:.8rem;padding:.2rem .5rem;border-radius:.5rem;background-color:var(--yellow);color:rgba(var(--foreground-color), 1);font-weight:500;justify-self:flex-start}.fab{position:absolute;right:0;bottom:0;margin:1.5rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);z-index:2}#scroll_to_top{border-radius:3rem;background-color:rgba(var(--foreground-color), 1)}#add_address_button{border-radius:.5rem;background-color:rgba(0,0,0,0);border:solid .1rem var(--accent-color)}.user-action-result__icon{justify-self:center;height:4rem;width:4rem;border-radius:5rem;margin-bottom:2rem;-webkit-animation:popup 1s;animation:popup 1s}.user-action-result__icon.success{fill:rgba(var(--background-color), 1);padding:1rem;background-color:#0bbe56}.user-action-result__icon.failed{background-color:rgba(var(--text-color), 0.03);fill:var(--danger-color)}@-webkit-keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}@keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}.cashier-request,.payment-request{display:flex;gap:1rem;align-items:center;padding:1rem;border-radius:.3rem;background-color:rgba(var(--foreground-color), 1)}.cashier-request:not(:last-of-type),.payment-request:not(:last-of-type){margin-bottom:.5rem}.cashier-request__mode,.payment-request__mode{text-align:center;width:2rem;font-size:.8rem}.cashier-request__time,.payment-request__time{font-size:.8rem}.cashier-request{display:grid;gap:.5rem 1rem;grid-template-columns:auto 1fr auto;grid-template-areas:"mode details status" "mode . status"}.cashier-request__mode{grid-area:mode}.cashier-request__details{grid-area:details;font-weight:700}.cashier-request__status,.cashier-request__requestor{font-size:.8rem}.cashier-request__status{grid-area:status;grid-column:3/4;grid-row:1/3}#payment_request_history{padding-bottom:3rem}.payment-request{display:grid;gap:.5rem 1rem;grid-template-columns:1fr auto;color:rgba(var(--text-color), 1)}.payment-request__requestor{font-weight:500}.payment-request__amount{font-weight:700;text-align:right}.payment-request__status{display:flex;align-items:center;font-size:.8rem;text-transform:capitalize}.payment-request__status .icon{height:1rem;width:1rem;margin-left:.3rem}.payment-request .icon.paid{fill:var(--green)}.payment-request .icon.declined{fill:var(--danger-color)}.payment-request .button{background-color:rgba(0,0,0,0);padding:.6rem .8rem;color:var(--accent-color);background-color:rgba(var(--foreground-color), 1)}.wallet-request{display:grid;gap:.5rem 1rem;padding:.5rem 0;border-radius:.5rem;grid-template-columns:auto 1fr}.wallet-request:not(.rejected,.pending).withdrawn .wallet-request__amount::before{content:"- "}.wallet-request:not(.rejected,.pending).added .wallet-request__amount{color:var(--green)}.wallet-request:not(.rejected,.pending).added .wallet-request__amount::before{content:"+ "}.wallet-request .icon.pending{fill:var(--yellow)}.wallet-request .icon.failed{fill:var(--danger-color)}.wallet-request__icon{display:flex;align-items:center;justify-content:center;grid-area:1/1/3/2;width:2.5rem;height:2.5rem;border-radius:2rem;background-color:rgba(var(--text-color), 0.06)}.wallet-request__icon .icon{fill:var(--accent-color)}.wallet-request__details{font-weight:500}.wallet-request__details,.wallet-request__amount{color:rgba(var(--text-color), 1)}.wallet-request__amount{font-weight:700}.wallet-request__time,.wallet-request__status{font-size:.8rem;color:rgba(var(--text-color), 0.8)}.wallet-request__status{text-align:right}.wallet-request__status .icon{margin-left:.3rem}#transaction__amount{font-size:2.5rem;font-weight:700}#transaction__remark,#transaction__note{line-height:1.6;justify-self:flex-start;background-color:rgba(var(--text-color), 0.06);border-radius:.5rem;padding:.8rem}#transaction__note .icon{fill:var(--danger-color);margin-right:.5rem}#saved_upi_ids_list{display:grid;gap:.5rem;width:min(24rem,100%)}.saved-upi{display:flex;justify-content:space-between;align-items:center;padding:.4rem .4rem .4rem 1rem;border-radius:.5rem;background-color:rgba(var(--text-color), 0.03)}@media screen and (max-width: 40rem){.inner-page{padding-bottom:7rem}#main_navbar.hide-away{bottom:0;left:0;right:0}.nav-item--active .icon{transform:translateY(50%)}.nav-item--active .nav-item__title{transform:translateY(100%);opacity:0}.integrated-action-button .icon:last-of-type{margin-left:auto}}@media screen and (min-width: 40rem){sm-popup{--width: 24rem}.popup__header{padding:1.5rem 1.5rem 0 .75rem}body{align-items:center;justify-content:center}#main_card{display:grid;grid-template-columns:10rem 1fr;grid-template-rows:auto 1fr;grid-template-areas:"header header" "navbar content"}#main_header{grid-area:header;padding:1rem 1.5rem;background-color:rgba(var(--foreground-color), 1)}#main_navbar{height:100%;grid-area:navbar}#main_navbar ul{flex-direction:column;gap:.3rem;padding:.3rem}.nav-item{padding:1rem;padding-right:2rem;border-radius:.5rem;flex-direction:row;justify-content:start;gap:.5rem;font-size:.9rem;opacity:.8}.nav-item--active{opacity:1}.nav-item__indicator{width:.25rem;height:50%;left:0;border-radius:0 1rem 1rem 0;bottom:auto}.card{padding:1.5rem}.balance-card>*{padding:1.5rem}#contact>*{padding:1rem 12vw}#contact>:last-child{padding:.5rem 12vw}#saved_ids_list{grid-template-columns:repeat(auto-fill, minmax(14rem, 1fr))}.inner-page{padding:1.5rem 14vw}}@media(any-hover: hover){::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-thumb{background:rgba(var(--text-color), 0.3);border-radius:1rem}::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-color), 0.5)}.interact:not([disabled]){transition:background-color .3s}.interact:not([disabled]):hover{background-color:rgba(var(--text-color), 0.06)}button:not([disabled]),.button:not([disabled]){transition:background-color .3s,filter .3s}button:not([disabled]):hover,.button:not([disabled]):hover{filter:contrast(2)}}@supports(overflow: overlay){body{overflow:overlay}}.hidden{display:none !important} \ No newline at end of file +*{padding:0;margin:0;box-sizing:border-box;font-family:"Inter",sans-serif}*:focus-visible{outline:var(--accent-color) solid medium;outline-offset:0;transition:outline-offset .3s}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%}body{--accent-color: #234ebf;--accent-color-rgb: 35, 78, 191;--blue-accent-1: #f5f8ff;--blue-accent-2: #f2f6ff;--text-color: 58, 58, 58;--foreground-color: 255, 255, 255;--background-color: 243, 245, 250;--danger-color: #ff6161;--green: #1cad59;--yellow: rgb(220, 165, 0);scrollbar-width:thin;scrollbar-gutter:stable;color:rgba(var(--text-color), 1);background-color:rgba(var(--foreground-color), 1);transition:background-color .3s;position:relative;display:flex;flex-direction:column}body[data-theme=dark]{--accent-color: #a0b6ff;--accent-color-rgb: 160, 182, 255;--blue-accent-1: #f5f8ff10;--blue-accent-2: #f2f6ff10;--text-color: 220, 220, 220;--foreground-color: 27, 28, 29;--background-color: 21, 22, 22;--danger-color: rgb(255, 106, 106);--green: #00e676;--yellow: rgb(255, 213, 5)}body[data-theme=dark] sm-popup::part(popup){background-color:rgba(var(--foreground-color), 1)}p,strong{font-size:.9rem;max-width:65ch;line-height:1.7;color:rgba(var(--text-color), 0.9)}.warning{line-height:normal;padding:1rem;background-color:khaki;border-radius:.5rem;font-weight:500;color:rgba(0,0,0,.7)}a{text-decoration:none;color:var(--accent-color)}.button,button{-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;display:inline-flex;border:none;background-color:rgba(0,0,0,0);overflow:hidden;-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;font-size:.9rem;font-weight:500;white-space:nowrap;padding:.8rem;border-radius:.5rem;justify-content:center;color:inherit;min-width:-webkit-max-content;min-width:-moz-max-content;min-width:max-content}.button:not(:disabled),button:not(:disabled){cursor:pointer}.button{color:var(--accent-color);background-color:var(--blue-accent-1)}.button .icon{fill:var(--accent-color)}.button--primary,.button--danger{color:rgba(var(--background-color), 1) !important}.button--primary .icon,.button--danger .icon{fill:rgba(var(--background-color), 1)}.button--primary{width:100%;background-color:var(--accent-color)}.button--danger{background-color:var(--danger-color)}.button--small{padding:.4rem .6rem}.cta{text-transform:uppercase;font-size:.8rem;font-weight:700;letter-spacing:.05em;padding:.8rem 1rem}.icon{width:1.2rem;height:1.2rem;fill:rgba(var(--text-color), 0.8);flex-shrink:0}.icon-only{padding:.5rem;border-radius:.3rem}button:disabled{opacity:.5}details summary{display:flex;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;align-items:center;justify-content:space-between}details[open] summary{margin-bottom:1rem}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-input,sm-textarea{--border-radius: 0.3rem;--background-color: rgba(var(--foreground-color), 1)}sm-input button .icon,sm-textarea button .icon{fill:var(--accent-color)}sm-copy{font-size:.9rem}sm-spinner{--size: 1rem;--stroke-width: 0.1rem}sm-form{--gap: 1rem}sm-select{--padding: 0.8rem;font-size:.9rem}sm-option{font-size:.9rem}sm-chips{--gap: 0.3rem}sm-chip{position:relative;font-size:.9rem;--border-radius: 0.5rem;--padding: 0.5rem 0.8rem;--background: rgba(var(--text-color), 0.06);-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:500}sm-chip[selected]{--background: var(--accent-color);color:rgba(var(--foreground-color), 1)}ul{list-style:none}ol{counter-reset:item}ol li{position:relative;display:flex;align-items:flex-start;counter-increment:item}ol li:not(:last-of-type){padding-bottom:1.5rem}ol li:not(:last-of-type)::after{content:"";position:absolute;width:.1rem;height:calc(100% - 2.2rem);background:var(--accent-color);margin-left:.7rem;margin-top:2rem}ol li::before{content:counter(item);display:flex;align-items:center;justify-content:center;text-align:center;font-size:.8rem;font-weight:500;margin-top:.15rem;margin-right:1rem;line-height:1;width:1.5rem;height:1.5rem;border-radius:100%;flex-shrink:0;color:rgba(var(--text-color), 0.8);background:rgba(var(--text-color), 0.1)}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.wrap-around{overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.full-bleed{grid-column:1/-1}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.sticky{position:-webkit-sticky;position:sticky}.top-0{top:0}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.grid{display:grid}.flow-column{grid-auto-flow:column}.gap-0-3{gap:.3rem}.gap-0-5{gap:.5rem}.gap-1{gap:1rem}.gap-1-5{gap:1.5rem}.gap-2{gap:2rem}.gap-3{gap:3rem}.text-align-right{text-align:right}.align-start{align-content:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.text-center{text-align:center}.justify-start{justify-items:start}.justify-center{justify-content:center}.justify-items-center{justify-items:center}.justify-right{margin-left:auto}.align-self-center{align-self:center}.align-self-end{align-self:end}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.flex-direction-column{flex-direction:column}.space-between{justify-content:space-between}.margin-right-0-3{margin-right:.3rem}.margin-right-0-5{margin-right:.5rem}.margin-right-auto{margin-right:auto}.margin-left-0-5{margin-left:.5rem}.margin-left-auto{margin-left:auto}.margin-top-1{margin-top:1rem}.margin-top-1-5{margin-top:1.5rem}.margin-bottom-0-5{margin-bottom:.5rem}.margin-bottom-1{margin-bottom:1rem}.margin-bottom-1-5{margin-bottom:1.5rem}.margin-bottom-2{margin-bottom:2rem}.padding-0-3{padding:.3rem}.padding-0-5{padding:.5rem}.padding-1{padding:1rem}.padding-inline-0-5{padding-inline:.5rem}.padding-inline-1{padding-inline:1rem}.padding-block-0-5{padding-block:.5rem}.padding-block-1{padding-block:1rem}.border-radius-0-3{border-radius:.3rem}.border-radius-0-5{border-radius:.5rem}.font-0-9{font-size:.9rem}.w-100{width:100%}.h-100{height:100%}.label{font-size:.8rem;color:rgba(var(--text-color), 0.8);font-weight:500;margin-bottom:.2rem}.button--primary .ripple,.button--danger .ripple{background:radial-gradient(circle, rgba(var(--background-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%)}.ripple{height:8rem;width:8rem;position:absolute;border-radius:50%;transform:scale(0);background:radial-gradient(circle, rgba(var(--text-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%);pointer-events:none}.interact{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0)}.empty-state{display:grid;width:100%;padding:1.5rem 0}.observe-empty-state:empty{display:none !important}.observe-empty-state:not(:empty)+.empty-state{display:none !important}.bullet-point{display:flex;align-items:center;justify-content:center;margin:0 .8ch}.bullet-point::after{content:"";height:.4ch;width:.4ch;border-radius:.5em;background-color:var(--accent-color)}.icon-button{padding:.6rem;border-radius:.8rem;background-color:rgba(var(--text-color), 0.1);height:-webkit-max-content;height:-moz-max-content;height:max-content}.icon-button .icon{fill:var(--accent-color)}.page{height:100%}.page__header{position:-webkit-sticky;position:sticky;top:0;display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;background-color:rgba(var(--foreground-color), 1);z-index:1}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{margin-bottom:.5rem}#confirmation_popup .flex,#prompt_popup .flex{margin-top:1rem}#prompt_message{margin-bottom:1.5rem}.popup__header{position:relative;display:grid;gap:.5rem;width:100%;padding:0 1.5rem 0 .5rem;align-items:center;grid-template-columns:auto 1fr}.popup__header>*{grid-row:1}.popup__header h3,.popup__header h4{grid-column:1/-1;justify-self:center;align-self:center}.popup__header__close{grid-column:1}.flo-icon{margin-right:.3rem;height:1.5rem;width:1.5rem}#secondary_pages{display:flex;flex-direction:column;width:100%}#secondary_pages header{padding:1.5rem}#secondary_pages .inner-page{height:100%}#landing>section{justify-content:center;justify-items:center;align-items:center;text-align:center;padding:8vw 0}#landing h1{font-size:clamp(2rem,5vw,5rem)}#sign_in,#sign_up{justify-content:center;align-items:center}#sign_in sm-form,#sign_up sm-form{margin:2rem 0}#sign_in{display:grid;align-content:center;padding:0;justify-items:center}#sign_in .illustration{height:auto;background-color:#4d77ff;border-radius:1rem;width:min(24rem,100%)}#sign_in section{width:min(24rem,100%);background-color:rgba(var(--foreground-color), 1);padding:max(1.5rem,2vw);border-radius:.5rem;margin-top:-1.6rem}#sign_up .h2{margin-bottom:.5rem}#sign_up .card{margin:1.5rem 0}#sign_up h5{color:rgba(var(--text-color), 0.8)}#flo_id_warning{padding-bottom:1.5rem;border-bottom:thin solid rgba(var(--text-color), 0.3)}#flo_id_warning .icon{height:4rem;width:4rem;padding:1rem;background-color:#ffc107;border-radius:3rem;fill:rgba(0,0,0,.8);margin-bottom:1.5rem}#main_header{display:grid;gap:1rem;padding:1rem;align-items:center;grid-template-columns:1fr auto auto auto;min-height:4rem}#user_profile_button{background-color:var(--blue-accent-1);border-radius:2rem;font-size:.8rem;padding:.6rem .8rem;font-weight:700}#notifications_wrapper{position:relative}#notifications_panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;background-color:rgba(var(--foreground-color), 1);padding:1rem}.logged-in-user-id{background-color:rgba(var(--text-color), 0.06);max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content;padding:.4rem .8rem .4rem .5rem;border-radius:2rem;font-weight:500}#main_card{position:relative;display:flex;flex-direction:column;height:100%;width:100%;transition:background-color .3s}#main_card.nav-hidden .inner-page{grid-area:2/1/3/-1}.badge{display:flex;align-items:center;justify-content:center;content:attr(data-notifications);position:absolute;top:0;right:0;font-size:.8rem;padding:.3rem;background:var(--danger-color);color:rgba(var(--background-color), 1);aspect-ratio:1/1;font-weight:700;border-radius:.3rem;margin:.3rem}.inner-page{display:flex;flex-direction:column;padding:0 1rem;flex:1;align-content:start;overflow-y:auto}.password-field label{display:flex;justify-content:center}.password-field label input:checked~.visible{display:none}.password-field label input:not(:checked)~.invisible{display:none}.multi-state-button{display:grid;text-align:center;align-items:center;justify-items:center}.multi-state-button>*{grid-area:1/1/2/2}.multi-state-button button{z-index:1}.scrolling-wrapper{overflow-y:auto}#home{position:relative;display:grid;padding:0;gap:3rem;overflow-y:visible;align-content:initial}#home>*{align-content:flex-start}#wallet_section{position:relative;display:flex;flex-direction:column;height:100%;gap:1.5rem;background-color:rgba(var(--accent-color-rgb), 0.02)}#wallet_section sm-chips{display:flex;justify-content:center}#wallet_section sm-chip::part(chip){width:8rem;justify-content:center}#wallet_section>*{width:100%}#wallet_section::before{content:"";position:absolute;top:-10vmax;left:0;width:100%;height:10vmax;background-color:inherit;pointer-events:none}#user,#cashier{position:relative;padding-bottom:1rem;align-content:flex-start}.swap-input{display:grid;grid-template-columns:6rem 1fr;background-color:rgba(var(--text-color), 0.06);border-radius:.5rem;padding:0 .2rem}.swap-input sm-input{--background: transparent}.swap-input sm-select{margin:.2rem 0;--background: rgba(var(--foreground-color), 1)}.swap-input sm-select[open]{z-index:10}#wallet_cards_wrapper{display:grid;grid-template-columns:6rem 1fr;background-color:rgba(var(--text-color), 0.06);border-radius:.5rem;padding:0 .2rem}#wallet_cards_wrapper sm-input{--background: transparent}#wallet_cards_wrapper sm-select{margin:.2rem 0;--background: rgba(var(--foreground-color), 1)}#wallet_cards_wrapper sm-select[open]{z-index:10}.balance-card{background-color:rgba(var(--accent-color-rgb), 0.06);border-radius:.5rem;padding:.8rem;font-size:.9rem}.balance-card>*{font-weight:500}#rupee_balance span:first-of-type,#flo_balance span:first-of-type,#btc_balance span:first-of-type{font-size:1.5rem}#rupee_balance span:nth-of-type(2),#flo_balance span:nth-of-type(2),#btc_balance span:nth-of-type(2){font-size:1rem}.actions-wrapper{display:flex;gap:.5rem}.actions-wrapper>*{flex:1}.wallet-action,.integrated-action-button{position:relative;color:inherit;font-weight:500;font-size:.9rem}.wallet-action .icon:first-of-type,.integrated-action-button .icon:first-of-type{height:3rem;width:3rem;padding:.95rem;overflow:visible;fill:var(--accent-color);border-radius:2rem;background-color:var(--blue-accent-2)}.wallet-action .badge,.integrated-action-button .badge{left:0;right:auto}.wallet-action{gap:.5rem;flex-direction:column;align-items:center;font-size:.8rem;white-space:initial;border-radius:.5rem;padding:0}.integrated-action-button{padding:0;justify-content:flex-start}.integrated-action-button .icon:first-of-type{margin-right:1rem}.integrated-action-button span:last-of-type{font-size:1rem}.cashier-status{font-size:.9rem;padding:1rem 1.2rem;border-radius:1rem;background-color:rgba(240,230,140,.8);color:rgba(0,0,0,.8)}.cashier-status .icon{fill:rgba(0,0,0,.8)}#topup_wallet__qr_code{background-color:rgba(var(--text-color), 0.03);border-radius:.5rem;height:10rem;justify-self:flex-start;width:10rem}#topup_wallet__qr_code svg{width:100%;height:100%;fill:rgba(var(--text-color), 1)}#cashier_status{font-size:.9rem;padding:1rem 1.2rem;border-radius:1rem;background-color:rgba(240,230,140,.8);color:rgba(0,0,0,.8)}#cashier_status .icon{fill:rgba(0,0,0,.8)}.remove-card-wrapper{min-height:2rem}.receiver-card{display:grid;gap:.5rem;padding:.5rem 0;border:none}.receiver-card:not(:last-of-type){border-bottom:solid thin rgba(var(--text-color), 0.3)}#contacts{position:relative}#recent_contacts{gap:0}#saved_ids_list{display:grid;gap:1rem;grid-template-columns:minmax(0, 1fr);margin-bottom:1.5rem}.saved-id{align-items:center;grid-template-columns:auto 1fr;gap:0 1rem;padding:.5rem 0;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:.5rem}.saved-id.highlight{box-shadow:0 0 .1rem .1rem var(--accent-color) inset}.saved-id .edit-saved{padding:.3rem;position:relative}.saved-id__initials{display:flex;align-items:center;justify-content:center;height:2.5rem;width:2.5rem;font-size:1.2rem;text-transform:uppercase;color:var(--accent-color);font-weight:700;line-height:1;background-color:rgba(var(--text-color), 0.03);border-radius:2rem;grid-area:1/1/3/2}.saved-id__title{align-self:flex-end;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.saved-id__flo-id{font-size:.8rem}.saved-id__copy{padding:.3rem .5rem;border-radius:.3rem;background-color:rgba(var(--text-color), 0.03)}#saved_ids_tip{background-color:rgba(var(--text-color), 0.03);border-radius:2rem;padding:.5rem .8rem .5rem .5rem}.card{background-color:rgba(var(--foreground-color), 1);border-radius:.5rem;padding:1rem}#contact{display:grid;grid-template-rows:auto 1fr auto;padding:0;height:100%}#contact>*{padding:1rem 1.5rem}#contact>:first-child{padding-top:0}#contact>:last-child{padding:.5rem 1.5rem;border-top:solid thin rgba(var(--text-color), 0.2)}#contact>:last-child button{padding:.8rem 2rem;border-radius:1rem;color:var(--accent-color);background-color:rgba(var(--text-color), 0.03)}#contact__transactions{position:relative;display:grid;gap:.5rem;overflow-y:auto;flex:1;padding:0 max(1rem,8vw) 1rem max(1rem,8vw);align-content:flex-start}#contact__transactions sm-spinner{position:absolute;justify-self:center;align-self:center}.transaction-message{background-color:rgba(var(--text-color), 0.06);padding:1rem;border-radius:.5rem;justify-self:flex-start;border-radius:0 1rem 1rem 1rem;gap:.5rem}.transaction-message.received{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}.transaction-message.received+.transaction-message.received{border-radius:1rem}.transaction-message.sent{margin-left:auto;justify-self:flex-end;border-radius:1rem 1rem 0 1rem;text-align:right}.transaction-message__amount{font-size:1.2rem}.transaction-message__time{opacity:.8;font-size:.8rem}#history_applied_filters{padding:.2rem 0 .5rem 0}.applied-filter{display:flex;align-items:center;padding:.5rem .6rem .5rem .8rem;border-radius:.5rem;border:solid thin rgba(var(--text-color), 0.2);text-transform:uppercase;font-size:.8rem;font-weight:500;letter-spacing:.08em}.applied-filter button{padding:.6rem}.applied-filter .icon{margin-left:.3rem}fieldset{border:none;padding:0;margin:0}fieldset legend{font-size:.8rem;font-weight:500;margin-bottom:.5rem}.category-chip{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .5rem;border-radius:.3rem;font-size:.8rem;border:solid thin rgba(var(--text-color), 0.2);font-weight:700}.category-chip input{display:none}.category-chip span{transition:transform .2s;transform:translateX(-0.8rem)}.category-chip .icon{opacity:0;transition:opacity .2s,transform .2s;margin-right:.3rem;fill:var(--accent-color);transform:translateX(0.5rem)}.category-chip input:checked~.icon{opacity:1;transform:translateX(0)}.category-chip input:checked~span{color:var(--accent-color);transform:translateX(0)}#wallet_history_wrapper{margin-top:1.5rem;padding-bottom:3rem}#payments_history{display:grid;gap:2rem;margin-top:1.5rem;padding-bottom:3rem}.transaction{grid-template-columns:auto 1fr auto;gap:.5rem 1rem;align-items:center}.transaction__amount{white-space:nowrap}.transaction.sent .icon--tx-type{fill:var(--danger-color)}.transaction.sent .transaction__amount{color:var(--danger-color)}.transaction.sent .transaction__amount::before{content:"- "}.transaction.received .icon--tx-type{fill:var(--green)}.transaction.received .transaction__amount{color:var(--green)}.transaction.received .transaction__amount::before{content:"+ "}.transaction__icon{position:relative;grid-area:icon;display:grid;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background-color:rgba(var(--text-color), 0.03);border-radius:2rem;grid-area:1/1/3/2}.transaction__icon>*{grid-area:1/1}.transaction__icon .icon--tx-type{position:absolute;background-color:inherit;right:-0.3rem;bottom:-0.3rem;border-radius:1rem;padding:.2rem;height:1.5rem;width:1.5rem;border:solid medium rgba(var(--foreground-color), 1)}.transaction__receiver{font-weight:500}.transaction__time{font-size:.8rem;color:rgba(var(--text-color), 0.8)}.transaction__amount{font-size:1rem;font-weight:500;grid-area:1/3/3/4}.btc-tx{grid-template-columns:auto 1fr auto;gap:.5rem 1rem;align-items:center;grid-template-areas:"icon time amount" "icon receiver receiver" "icon txid txid"}.btc-tx__amount{white-space:nowrap}.btc-tx.out .icon--tx-type{fill:var(--danger-color)}.btc-tx.out .btc-tx__amount{color:var(--danger-color)}.btc-tx.out .btc-tx__amount::before{content:"- "}.btc-tx.in .icon--tx-type{fill:var(--green)}.btc-tx.in .btc-tx__amount{color:var(--green)}.btc-tx.in .btc-tx__amount::before{content:"+ "}.btc-tx.unconfirmed-tx{grid-template-areas:"icon time amount" "icon receiver receiver" "icon txid txid" "icon unconfirmed unconfirmed" "icon badge badge"}.btc-tx.unconfirmed-tx .icon{fill:var(--yellow)}.btc-tx__icon{position:relative;grid-area:icon;display:grid;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background-color:rgba(var(--text-color), 0.03);border-radius:2rem}.btc-tx__icon>*{grid-area:1/1}.btc-tx__icon .icon--tx-type{position:absolute;background-color:inherit;right:-0.3rem;bottom:-0.3rem;border-radius:1rem;padding:.2rem;height:1.5rem;width:1.5rem;border:solid medium rgba(var(--foreground-color), 1)}.btc-tx__receiver{grid-area:receiver;font-weight:500}.btc-tx__time{grid-area:time;font-size:.8rem;color:rgba(var(--text-color), 0.8)}.btc-tx__amount{grid-area:amount;font-size:1rem;font-weight:500}.btc-tx__id{grid-area:txid;font-size:.8rem;color:rgba(var(--text-color), 0.8)}.btc-tx .unconfirmed-wrapper{grid-area:unconfirmed;padding:.5rem 0}.btc-tx .pending-badge{grid-area:badge;font-size:.8rem;padding:.2rem .5rem;border-radius:.5rem;background-color:var(--yellow);color:rgba(var(--foreground-color), 1);font-weight:500;justify-self:flex-start}.fab{position:absolute;right:0;bottom:0;margin:1.5rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);z-index:2}#scroll_to_top{border-radius:3rem;background-color:rgba(var(--foreground-color), 1)}.user-action-result__icon{justify-self:center;height:4rem;width:4rem;border-radius:5rem;margin-bottom:2rem;-webkit-animation:popup 1s;animation:popup 1s}.user-action-result__icon.success{fill:rgba(var(--background-color), 1);padding:1rem;background-color:#0bbe56}.user-action-result__icon.failed{background-color:rgba(var(--text-color), 0.03);fill:var(--danger-color)}@-webkit-keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}@keyframes popup{0%{opacity:0;transform:scale(0.2) translateY(600%)}10%{transform:scale(0.2) translateY(5rem);opacity:1}40%{transform:scale(0.2) translateY(0)}80%{transform:scale(1.1) translateY(0)}100%{transform:scale(1) translateY(0)}}.cashier-request,.payment-request{display:flex;gap:1rem;align-items:center;padding:1rem;border-radius:.3rem;background-color:rgba(var(--foreground-color), 1)}.cashier-request:not(:last-of-type),.payment-request:not(:last-of-type){margin-bottom:.5rem}.cashier-request__mode,.payment-request__mode{text-align:center;width:2rem;font-size:.8rem}.cashier-request__time,.payment-request__time{font-size:.8rem}.cashier-request{display:grid;gap:.5rem 1rem;grid-template-columns:auto 1fr auto;grid-template-areas:"mode details status" "mode . status"}.cashier-request__mode{grid-area:mode}.cashier-request__details{grid-area:details;font-weight:700}.cashier-request__status,.cashier-request__requestor{font-size:.8rem}.cashier-request__status{grid-area:status;grid-column:3/4;grid-row:1/3}#payment_request_history{padding-bottom:3rem}.payment-request{display:grid;gap:.5rem 1rem;grid-template-columns:1fr auto;color:rgba(var(--text-color), 1)}.payment-request__requestor{font-weight:500}.payment-request__amount{font-weight:700;text-align:right}.payment-request__status{display:flex;align-items:center;font-size:.8rem;text-transform:capitalize}.payment-request__status .icon{height:1rem;width:1rem;margin-left:.3rem}.payment-request .icon.paid{fill:var(--green)}.payment-request .icon.declined{fill:var(--danger-color)}.payment-request .button{background-color:rgba(0,0,0,0);padding:.6rem .8rem;color:var(--accent-color);background-color:rgba(var(--foreground-color), 1)}.payment-request--pending{padding:0}.wallet-request{display:grid;gap:.5rem 1rem;padding:.5rem 0;border-radius:.5rem;grid-template-columns:auto 1fr}.wallet-request:not(.rejected,.pending).withdrawn .wallet-request__amount::before{content:"- "}.wallet-request:not(.rejected,.pending).added .wallet-request__amount{color:var(--green)}.wallet-request:not(.rejected,.pending).added .wallet-request__amount::before{content:"+ "}.wallet-request .icon.pending{fill:var(--yellow)}.wallet-request .icon.failed{fill:var(--danger-color)}.wallet-request__icon{display:flex;align-items:center;justify-content:center;grid-area:1/1/3/2;width:2.5rem;height:2.5rem;border-radius:2rem;background-color:rgba(var(--text-color), 0.06)}.wallet-request__icon .icon{fill:var(--accent-color)}.wallet-request__details{font-weight:500}.wallet-request__details,.wallet-request__amount{color:rgba(var(--text-color), 1)}.wallet-request__amount{font-weight:700}.wallet-request__time,.wallet-request__status{font-size:.8rem;color:rgba(var(--text-color), 0.8)}.wallet-request__status{text-align:right}.wallet-request__status .icon{margin-left:.3rem}#transaction__amount{font-size:2.5rem;font-weight:700}#transaction__remark,#transaction__note{line-height:1.6;justify-self:flex-start;background-color:rgba(var(--text-color), 0.06);border-radius:.5rem;padding:.8rem}#transaction__note .icon{fill:var(--danger-color);margin-right:.5rem}#saved_upi_ids_list{display:grid;gap:.5rem;width:min(24rem,100%)}.saved-upi{display:flex;justify-content:space-between;align-items:center;padding:.4rem .4rem .4rem 1rem;border-radius:.5rem;background-color:rgba(var(--text-color), 0.03)}@media screen and (max-width: 40rem){#home{padding-bottom:3rem}#home>*{padding:0 1rem}.integrated-action-button .icon:last-of-type{margin-left:auto}.nav-item--active .icon{transform:translateY(50%)}.nav-item--active .nav-item__title{transform:translateY(100%);opacity:0}.integrated-action-button .icon:last-of-type{margin-left:auto}.hide-on-mobile{display:none}}@media screen and (min-width: 40rem){sm-popup{--width: 24rem}.popup__header{padding:1.5rem 1.5rem 0 .75rem}body{align-items:center;justify-content:center}.inner-page{padding:0 14vw}#main_header{padding:1.5rem 3vw}.card{padding:1.5rem}#home{grid-template-columns:26rem 1fr;gap:4vw;padding-right:3vw}#profile_popup{--width: 32rem}#notifications_panel{position:absolute;top:100%;left:auto;bottom:auto;right:0;border-radius:.5rem;z-index:10;box-shadow:0 .5rem 1rem rgba(0,0,0,.1);border:solid 1px rgba(var(--text-color), 0.1);background-color:rgba(var(--foreground-color), 1);width:max(24rem,100%)}#wallet_section{padding:0 3vw;grid-row:1/3}#contact>*{padding:1rem 12vw}#contact>:last-child{padding:.5rem 12vw}#saved_ids_list{gap:1.5rem;grid-template-columns:repeat(auto-fill, minmax(16rem, 1fr))}.hide-on-desktop{display:none}}@media screen and (min-width: 68rem){#home{grid-template-columns:26rem 1fr 1fr}}@media(any-hover: hover){::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-thumb{background:rgba(var(--text-color), 0.3);border-radius:1rem}::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-color), 0.5)}.button--primary:not([disabled]),.button--danger:not([disabled]){transition:filter .3s}.button--primary:not([disabled]):hover,.button--danger:not([disabled]):hover{filter:brightness(1.3)}.interact:not([disabled]),button:not([disabled],.button--primary,.button--danger),.button:not([disabled],.button--primary,.button--danger){transition:background-color .3s}.interact:not([disabled]):hover,button:not([disabled],.button--primary,.button--danger):hover,.button:not([disabled],.button--primary,.button--danger):hover{background-color:rgba(var(--text-color), 0.06)}}@supports(overflow: overlay){body{overflow:overlay}}.hidden{display:none !important} \ No newline at end of file diff --git a/css/main.scss b/css/main.scss index f1a9119..e893777 100644 --- a/css/main.scss +++ b/css/main.scss @@ -2,7 +2,12 @@ padding: 0; margin: 0; box-sizing: border-box; - font-family: "Roboto", sans-serif; + font-family: "Inter", sans-serif; + &:focus-visible { + outline: var(--accent-color) solid medium; + outline-offset: 0; + transition: outline-offset 0.3s; + } } :root { font-size: clamp(1rem, 1.2vmax, 1.2rem); @@ -14,17 +19,20 @@ body { } body { - --accent-color: #4d77ff; - --text-color: 20, 20, 20; - --foreground-color: 252, 253, 255; - --background-color: 241, 243, 248; - --danger-color: rgb(255, 75, 75); + --accent-color: #234ebf; + --accent-color-rgb: 35, 78, 191; + --blue-accent-1: #f5f8ff; + --blue-accent-2: #f2f6ff; + --text-color: 58, 58, 58; + --foreground-color: 255, 255, 255; + --background-color: 243, 245, 250; + --danger-color: #ff6161; --green: #1cad59; --yellow: rgb(220, 165, 0); scrollbar-width: thin; scrollbar-gutter: stable; color: rgba(var(--text-color), 1); - background-color: rgba(var(--background-color), 1); + background-color: rgba(var(--foreground-color), 1); transition: background-color 0.3s; position: relative; display: flex; @@ -33,6 +41,9 @@ body { body[data-theme="dark"] { --accent-color: #a0b6ff; + --accent-color-rgb: 160, 182, 255; + --blue-accent-1: #f5f8ff10; + --blue-accent-2: #f2f6ff10; --text-color: 220, 220, 220; --foreground-color: 27, 28, 29; --background-color: 21, 22, 22; @@ -62,18 +73,8 @@ strong { a { text-decoration: none; color: var(--accent-color); - &:focus-visible { - box-shadow: 0 0 0 0.1rem rgba(var(--text-color), 1) inset; - } } -a.button { - padding: 0.4rem 0.6rem; - border-radius: 0.3rem; - font-size: 0.9rem; - font-weight: 500; - color: inherit; -} - +.button, button { user-select: none; position: relative; @@ -87,19 +88,17 @@ button { font-weight: 500; white-space: nowrap; padding: 0.8rem; - border-radius: 0.3rem; + border-radius: 0.5rem; justify-content: center; color: inherit; - &:focus-visible { - outline: var(--accent-color) solid medium; - } + min-width: max-content; &:not(:disabled) { cursor: pointer; } } .button { color: var(--accent-color); - background-color: rgba(var(--text-color), 0.06); + background-color: var(--blue-accent-1); .icon { fill: var(--accent-color); } @@ -143,17 +142,12 @@ button:disabled { opacity: 0.5; } -a:any-link:focus-visible { - outline: rgba(var(--text-color), 1) 0.1rem solid; -} - details summary { display: flex; user-select: none; cursor: pointer; align-items: center; justify-content: space-between; - color: var(--accent-color); } details[open] { @@ -175,23 +169,8 @@ sm-textarea { } } } -sm-button { - --padding: 0.8rem; - &[variant="primary"] { - .icon { - fill: rgba(var(--background-color), 1); - } - } - - &[disabled] { - .icon { - fill: rgba(var(--text-color), 0.6); - } - } - &.danger { - --background: var(--danger-color); - color: rgba(var(--background-color), 1); - } +sm-copy { + font-size: 0.9rem; } sm-spinner { --size: 1rem; @@ -208,21 +187,23 @@ sm-option { font-size: 0.9rem; } sm-chips { - --gap: 0; - background-color: rgba(var(--text-color), 0.06); - border-radius: 0.3rem; - padding: 0.3rem; + --gap: 0.3rem; } + sm-chip { - font-size: 0.8rem; - --border-radius: 0.2rem; - user-select: none; -} -sm-copy { + position: relative; font-size: 0.9rem; + --border-radius: 0.5rem; + --padding: 0.5rem 0.8rem; + --background: rgba(var(--text-color), 0.06); + user-select: none; + font-weight: 500; + &[selected] { + --background: var(--accent-color); + color: rgba(var(--foreground-color), 1); + } } -ul, -ol { +ul { list-style: none; } ol { @@ -403,7 +384,9 @@ ol { .margin-right-0-5 { margin-right: 0.5rem; } - +.margin-right-auto { + margin-right: auto; +} .margin-left-0-5 { margin-left: 0.5rem; } @@ -540,16 +523,15 @@ ol { .page { height: 100%; &__header { + position: sticky; + top: 0; display: flex; - justify-content: space-between; + flex-direction: column; + align-items: flex-start; + gap: 1rem; margin-bottom: 1.5rem; - min-height: 5rem; - .grid { - margin-top: auto; - } - h1 { - font-size: 2rem; - } + background-color: rgba(var(--foreground-color), 1); + z-index: 1; } } #confirmation_popup, @@ -671,12 +653,32 @@ ol { } #main_header { display: grid; - gap: 1.5rem; - padding: 1rem 1rem; + gap: 1rem; + padding: 1rem; align-items: center; - grid-template-columns: minmax(0, 1fr) auto; + grid-template-columns: 1fr auto auto auto; min-height: 4rem; } +#user_profile_button { + background-color: var(--blue-accent-1); + border-radius: 2rem; + font-size: 0.8rem; + padding: 0.6rem 0.8rem; + font-weight: 700; +} +#notifications_wrapper { + position: relative; +} +#notifications_panel { + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 10; + background-color: rgba(var(--foreground-color), 1); + padding: 1rem; +} .logged-in-user-id { background-color: rgba(var(--text-color), 0.06); max-width: fit-content; @@ -691,62 +693,12 @@ ol { height: 100%; width: 100%; transition: background-color 0.3s; - background-color: rgba(var(--background-color), 1); &.nav-hidden { .inner-page { grid-area: 2/1/3/-1; } } } - -#main_navbar { - display: flex; - background-color: rgba(var(--foreground-color), 0.8); - ul { - display: flex; - height: 100%; - width: 100%; - li { - width: 100%; - } - } -} -.nav-item { - position: relative; - display: flex; - flex: 1; - width: 100%; - flex-direction: column; - align-items: center; - justify-content: center; - padding: 0.5rem 0.3rem; - color: var(--text-color); - font-size: 0.8rem; - font-weight: 500; - gap: 0.5rem; - .icon { - transition: transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); - } - &__title { - transition: opacity 0.2s, - transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); - } - &--active { - color: var(--accent-color); - .icon { - fill: var(--accent-color); - } - } - &__indicator { - position: absolute; - bottom: 0; - width: 2rem; - height: 0.3rem; - background: var(--accent-color); - border-radius: 1rem 1rem 0 0; - z-index: 1; - } -} .badge { display: flex; align-items: center; @@ -801,9 +753,44 @@ ol { overflow-y: auto; } #home { + position: relative; + display: grid; + padding: 0; + gap: 3rem; + overflow-y: visible; + align-content: initial; + & > * { + align-content: flex-start; + } +} +#wallet_section { position: relative; display: flex; flex-direction: column; + height: 100%; + gap: 1.5rem; + background-color: rgba(var(--accent-color-rgb), 0.02); + sm-chips { + display: flex; + justify-content: center; + } + sm-chip::part(chip) { + width: 8rem; + justify-content: center; + } + > * { + width: 100%; + } + &::before { + content: ""; + position: absolute; + top: -10vmax; + left: 0; + width: 100%; + height: 10vmax; + background-color: inherit; + pointer-events: none; + } } #user, #cashier { @@ -830,40 +817,28 @@ ol { } #wallet_cards_wrapper { display: grid; - gap: 0.5rem; - grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr)); - align-items: flex-start; + grid-template-columns: 6rem 1fr; + background-color: rgba(var(--text-color), 0.06); + border-radius: 0.5rem; + padding: 0 0.2rem; + sm-input { + --background: transparent; + } + sm-select { + margin: 0.2rem 0; + --background: rgba(var(--foreground-color), 1); + &[open] { + z-index: 10; + } + } } .balance-card { - display: grid; - overflow: hidden; - border-radius: 0.8rem; - background-color: rgba(var(--foreground-color), 1); + background-color: rgba(var(--accent-color-rgb), 0.06); + border-radius: 0.5rem; + padding: 0.8rem; + font-size: 0.9rem; & > * { - padding: 1rem; - gap: 1.5rem; - } - - & > :last-child:not(:only-child) { - border-top: thin solid rgba(var(--text-color), 0.2); - } - .asset-icon { - height: 2.5rem; - width: 2.5rem; - padding: 0.6rem; - border-radius: 1.1rem; - margin-right: 0.8rem; - fill: rgba(var(--background-color), 1); - } - .asset-icon--rupee { - background-color: var(--green); - } - .asset-icon--flo { - fill: white; - background-color: #4d77ff; - } - .asset-icon--btc { - background-color: rgba(255, 173, 8); + font-weight: 500; } } #rupee_balance, @@ -877,19 +852,26 @@ ol { } } .actions-wrapper { - display: grid; + display: flex; gap: 0.5rem; - grid-template-columns: repeat(auto-fill, minmax(4rem, 1fr)); + > * { + flex: 1; + } } .wallet-action, .integrated-action-button { position: relative; color: inherit; font-weight: 500; + font-size: 0.9rem; .icon:first-of-type { - height: 1.5rem; - width: 1.5rem; + height: 3rem; + width: 3rem; + padding: 0.95rem; + overflow: visible; fill: var(--accent-color); + border-radius: 2rem; + background-color: var(--blue-accent-2); } .badge { left: 0; @@ -897,20 +879,13 @@ ol { } } .wallet-action { + gap: 0.5rem; flex-direction: column; - text-align: center; align-items: center; font-size: 0.8rem; white-space: initial; - padding: 0.8rem; - border: solid thin rgba(var(--text-color), 0.1); border-radius: 0.5rem; - &:hover { - border: solid thin rgba(var(--text-color), 0.5); - } - .icon { - margin-bottom: 0.8rem; - } + padding: 0; } .integrated-action-button { padding: 0; @@ -918,8 +893,8 @@ ol { .icon:first-of-type { margin-right: 1rem; } - .icon:last-of-type { - margin-left: 0.5rem; + span:last-of-type { + font-size: 1rem; } } .cashier-status { @@ -970,49 +945,43 @@ ol { #contacts { position: relative; } +#recent_contacts { + gap: 0; +} #saved_ids_list { display: grid; - gap: 0.5rem; + gap: 1rem; grid-template-columns: minmax(0, 1fr); margin-bottom: 1.5rem; } .saved-id { + align-items: center; grid-template-columns: auto 1fr; - gap: 0 0.8rem; - border-radius: 0.5rem; - padding: 0.5rem; + gap: 0 1rem; + padding: 0.5rem 0; user-select: none; - background-color: rgba(var(--foreground-color), 1); + border-radius: 0.5rem; &.highlight { box-shadow: 0 0 0.1rem 0.1rem var(--accent-color) inset; } .edit-saved { - grid-area: 1/1/3/2; padding: 0.3rem; position: relative; - .icon { - position: absolute; - right: 0; - bottom: 0; - border-radius: 0.5rem; - padding: 0.2rem; - background-color: rgba(var(--background-color), 1); - } } &__initials { display: flex; align-items: center; justify-content: center; - height: 2.4rem; - width: 2.4rem; + height: 2.5rem; + width: 2.5rem; font-size: 1.2rem; text-transform: uppercase; - color: rgba(var(--background-color), 1); + color: var(--accent-color); font-weight: 700; line-height: 1; - background-color: var(--accent-color); - justify-self: flex-start; + background-color: rgba(var(--text-color), 0.03); border-radius: 2rem; + grid-area: 1/1/3/2; } &__title { align-self: flex-end; @@ -1024,6 +993,11 @@ ol { &__flo-id { font-size: 0.8rem; } + &__copy { + padding: 0.3rem 0.5rem; + border-radius: 0.3rem; + background-color: rgba(var(--text-color), 0.03); + } } #saved_ids_tip { background-color: rgba(var(--text-color), 0.03); @@ -1101,25 +1075,14 @@ ol { font-size: 0.8rem; } } - -#history { - .page__header { - margin-bottom: 0; - } -} -#history_applied_filters_wrapper { - position: sticky; - top: 0; +#history_applied_filters { padding: 0.2rem 0 0.5rem 0; - background-color: rgba(var(--background-color), 1); - z-index: 1; - transition: background-color 0.3s; } .applied-filter { display: flex; align-items: center; padding: 0.5rem 0.6rem 0.5rem 0.8rem; - border-radius: 1rem; + border-radius: 0.5rem; border: solid thin rgba(var(--text-color), 0.2); text-transform: uppercase; font-size: 0.8rem; @@ -1132,6 +1095,16 @@ ol { margin-left: 0.3rem; } } +fieldset { + border: none; + padding: 0; + margin: 0; + legend { + font-size: 0.8rem; + font-weight: 500; + margin-bottom: 0.5rem; + } +} .category-chip { display: inline-flex; align-items: center; @@ -1141,11 +1114,6 @@ ol { font-size: 0.8rem; border: solid thin rgba(var(--text-color), 0.2); font-weight: 700; - letter-spacing: 0.08em; - text-transform: uppercase; - &:focus { - outline: solid var(--accent-color); - } input { display: none; } @@ -1178,6 +1146,7 @@ ol { display: grid; gap: 2rem; margin-top: 1.5rem; + padding-bottom: 3rem; } .transaction { grid-template-columns: auto 1fr auto; @@ -1187,18 +1156,18 @@ ol { white-space: nowrap; } &.sent { - .icon { - fill: rgba(var(--text-color), 0.8); + .icon--tx-type { + fill: var(--danger-color); } .transaction__amount { - color: rgba(var(--text-color), 0.8); + color: var(--danger-color); &::before { content: "- "; } } } &.received { - .icon { + .icon--tx-type { fill: var(--green); } .transaction__amount { @@ -1209,14 +1178,30 @@ ol { } } &__icon { - display: flex; + position: relative; + grid-area: icon; + display: grid; align-items: center; justify-content: center; - grid-area: 1/1/3/2; width: 2.5rem; height: 2.5rem; background-color: rgba(var(--text-color), 0.03); border-radius: 2rem; + grid-area: 1/1/3/2; + & > * { + grid-area: 1/1; + } + .icon--tx-type { + position: absolute; + background-color: inherit; + right: -0.3rem; + bottom: -0.3rem; + border-radius: 1rem; + padding: 0.2rem; + height: 1.5rem; + width: 1.5rem; + border: solid medium rgba(var(--foreground-color), 1); + } } &__receiver { font-weight: 500; @@ -1227,7 +1212,7 @@ ol { } &__amount { font-size: 1rem; - font-weight: 700; + font-weight: 500; grid-area: 1/3/3/4; } } @@ -1236,14 +1221,11 @@ ol { gap: 0.5rem 1rem; align-items: center; grid-template-areas: "icon time amount" "icon receiver receiver" "icon txid txid"; - &:not(:last-of-type) { - padding-bottom: 1rem; - } &__amount { white-space: nowrap; } &.out { - .icon { + .icon--tx-type { fill: var(--danger-color); } .btc-tx__amount { @@ -1254,7 +1236,7 @@ ol { } } &.in { - .icon { + .icon--tx-type { fill: var(--green); } .btc-tx__amount { @@ -1271,14 +1253,29 @@ ol { } } &__icon { + position: relative; grid-area: icon; - display: flex; + display: grid; align-items: center; justify-content: center; width: 2.5rem; height: 2.5rem; background-color: rgba(var(--text-color), 0.03); border-radius: 2rem; + & > * { + grid-area: 1/1; + } + .icon--tx-type { + position: absolute; + background-color: inherit; + right: -0.3rem; + bottom: -0.3rem; + border-radius: 1rem; + padding: 0.2rem; + height: 1.5rem; + width: 1.5rem; + border: solid medium rgba(var(--foreground-color), 1); + } } &__receiver { grid-area: receiver; @@ -1286,17 +1283,17 @@ ol { } &__time { grid-area: time; - font-size: 0.9rem; + font-size: 0.8rem; color: rgba(var(--text-color), 0.8); } &__amount { grid-area: amount; font-size: 1rem; - font-weight: 700; + font-weight: 500; } &__id { grid-area: txid; - font-size: 0.9rem; + font-size: 0.8rem; color: rgba(var(--text-color), 0.8); } .unconfirmed-wrapper { @@ -1326,11 +1323,6 @@ ol { border-radius: 3rem; background-color: rgba(var(--foreground-color), 1); } -#add_address_button { - border-radius: 0.5rem; - background-color: transparent; - border: solid 0.1rem var(--accent-color); -} .user-action-result__icon { justify-self: center; height: 4rem; @@ -1448,6 +1440,9 @@ ol { color: var(--accent-color); background-color: rgba(var(--foreground-color), 1); } + &--pending { + padding: 0; + } } .wallet-request { display: grid; @@ -1545,14 +1540,15 @@ ol { background-color: rgba(var(--text-color), 0.03); } @media screen and (max-width: 40rem) { - .inner-page { - padding-bottom: 7rem; + #home { + padding-bottom: 3rem; + > * { + padding: 0 1rem; + } } - #main_navbar { - &.hide-away { - bottom: 0; - left: 0; - right: 0; + .integrated-action-button { + .icon:last-of-type { + margin-left: auto; } } .nav-item { @@ -1571,6 +1567,9 @@ ol { margin-left: auto; } } + .hide-on-mobile { + display: none; + } } @media screen and (min-width: 40rem) { sm-popup { @@ -1583,55 +1582,39 @@ ol { align-items: center; justify-content: center; } - #main_card { - display: grid; - grid-template-columns: 10rem 1fr; - grid-template-rows: auto 1fr; - grid-template-areas: - "header header" - "navbar content"; + .inner-page { + padding: 0 14vw; } #main_header { - grid-area: header; - padding: 1rem 1.5rem; - background-color: rgba(var(--foreground-color), 1); - } - #main_navbar { - height: 100%; - grid-area: navbar; - ul { - flex-direction: column; - gap: 0.3rem; - padding: 0.3rem; - } - } - .nav-item { - padding: 1rem; - padding-right: 2rem; - border-radius: 0.5rem; - flex-direction: row; - justify-content: start; - gap: 0.5rem; - font-size: 0.9rem; - opacity: 0.8; - &--active { - opacity: 1; - } - &__indicator { - width: 0.25rem; - height: 50%; - left: 0; - border-radius: 0 1rem 1rem 0; - bottom: auto; - } + padding: 1.5rem 3vw; } .card { padding: 1.5rem; } - .balance-card { - & > * { - padding: 1.5rem; - } + #home { + grid-template-columns: 26rem 1fr; + gap: 4vw; + padding-right: 3vw; + } + #profile_popup { + --width: 32rem; + } + #notifications_panel { + position: absolute; + top: 100%; + left: auto; + bottom: auto; + right: 0; + border-radius: 0.5rem; + z-index: 10; + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1); + border: solid 1px rgba(var(--text-color), 0.1); + background-color: rgba(var(--foreground-color), 1); + width: max(24rem, 100%); + } + #wallet_section { + padding: 0 3vw; + grid-row: 1/3; } #contact { & > * { @@ -1642,10 +1625,16 @@ ol { } } #saved_ids_list { - grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr)); + gap: 1.5rem; + grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr)); } - .inner-page { - padding: 1.5rem 14vw; + .hide-on-desktop { + display: none; + } +} +@media screen and (min-width: 68rem) { + #home { + grid-template-columns: 26rem 1fr 1fr; } } @media (any-hover: hover) { @@ -1661,19 +1650,21 @@ ol { background: rgba(var(--text-color), 0.5); } } - .interact:not([disabled]) { + .button--primary:not([disabled]), + .button--danger:not([disabled]) { + transition: filter 0.3s; + &:hover { + filter: brightness(1.3); + } + } + .interact:not([disabled]), + button:not([disabled], .button--primary, .button--danger), + .button:not([disabled], .button--primary, .button--danger) { transition: background-color 0.3s; &:hover { background-color: rgba(var(--text-color), 0.06); } } - button:not([disabled]), - .button:not([disabled]) { - transition: background-color 0.3s, filter 0.3s; - &:hover { - filter: contrast(2); - } - } } @supports (overflow: overlay) { diff --git a/index.html b/index.html index 8ee3fed..17b6258 100644 --- a/index.html +++ b/index.html @@ -2,7 +2,7 @@ - FLO Pay + FLOpay - + - @@ -1629,24 +1510,43 @@ - - +