flopay/css/main.scss
2020-09-09 21:50:56 +05:30

1292 lines
24 KiB
SCSS

* {
box-sizing: border-box;
padding: 0;
margin: 0;
font-family: 'Roboto', sans-serif;
}
:root {
scroll-behavior: smooth;
}
body {
--accent-color: #303F9F;
--text-color: 17, 17, 17;
--text-color-light: 85, 85, 85;
--foreground-color: 255, 255, 255;
--background-color: #e8e8e8;
--dark-shade: #dadada;
background: var(--foreground-color);
color: rgba(var(--text-color), 1);
font-size: 16px;
}
a {
font-weight: 600;
text-decoration: none;
color: var(--accent-color);
}
.dark-text {
color: #111;
}
h1 {
font-size: 3.5rem;
}
h2 {
font-size: 2rem;
}
h3 {
font-size: 1.5rem;
}
h4 {
font-size: 1rem;
}
h5 {
font-size: 0.8rem;
}
h1,
h2,
h3,
h4,
h5 {
font-family: 'Poppins', sans-serif;
font-weight: 600;
}
p {
line-height: 1.5;
max-width: 60ch;
color: rgba(var(--text-color), 0.9);
}
button {
position: relative;
display: inline-flex;
align-items: center;
justify-content: center;
text-transform: capitalize;
padding: 0.6rem 1.2rem;
font-weight: 600;
cursor: pointer;
border-radius: 0.3rem;
color: var(--accent-color);
transition: transform 0.3s;
border: none;
background: rgba(var(--text-color), 0.1);
-webkit-tap-highlight-color: transparent;
font-family: 'Poppins', sans-serif;
&:focus {
outline: thin solid rgba(var(--text-color-light), .4);
}
&:disabled {
cursor: default;
background: rgba(var(--text-color), 0.5);
}
&:disabled~.loader {
opacity: 0;
}
}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
-webkit-appearance: none;
margin: 0;
}
input[type=text]::-ms-clear {
display: none;
width: 0;
height: 0;
}
input[type=text]::-ms-reveal {
display: none;
width: 0;
height: 0;
}
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
display: none;
}
input[type=number] {
-moz-appearance: textfield;
}
input:invalid {
outline: none;
box-shadow: none;
}
::-moz-focus-inner {
border: none;
}
.bottom-padding {
padding-bottom: 1.5rem;
}
.top-padding {
padding-top: 1em;
}
.bottom-margin {
margin-bottom: 1.5rem;
}
.top-margin {
margin-top: 1.5rem;
}
.flex {
display: flex;
}
.grid {
display: grid;
}
.grid-2 {
grid-template-columns: auto auto;
gap: 1em;
}
.align-center {
align-items: center;
}
.direction-column {
flex-direction: column;
}
.space-between {
justify-content: space-between;
}
.label {
margin-bottom: 0.4rem;
}
.light-text {
color: rgba(var(--text-color-light), 1);
}
.hide {
opacity: 0;
pointer-events: none;
}
.hide-completely {
display: none !important;
}
.breakable {
word-break: break-all;
}
.separator {
padding: .1em;
}
.no-transformations {
transform: none !important;
}
.loader {
fill: none;
stroke-width: 10;
stroke: var(--accent-color);
height: 2rem;
width: 2rem;
overflow: visible;
stroke-dashoffset: 230;
stroke-dasharray: 230;
padding: 2px;
justify-self: center;
}
@keyframes rotate {
100% {
transform: rotate(360deg);
}
}
@keyframes load {
50% {
stroke-dashoffset: 0;
}
100% {
stroke-dashoffset: -210;
}
}
.action {
position: relative;
display: inline-flex;
align-items: center;
justify-content: center;
padding: 0;
background: none;
&[disabled] {
.primary-btn {
background: none;
}
}
h4 {
padding: 0.5rem 0.8rem;
font-size: 0.9rem;
clip-path: circle(100%);
transition: clip-path 0.3s;
border-radius: 0.2rem;
}
.btn {
z-index: 2;
}
.loader {
position: absolute;
z-index: 1;
padding: 0.4em;
}
}
.clip {
clip-path: circle(0) !important;
}
.animate-loader {
animation: load 2.6s infinite, rotate 1s infinite linear;
}
.expand {
width: 100%;
}
.fade-left {
animation: fadeleft 0.3s;
}
.fade-right {
animation: faderight 0.3s;
}
@keyframes faderight {
from {
opacity: 0;
transform: translateX(-1em);
}
to {
opacity: 1;
transform: none;
}
}
@keyframes fadeleft {
from {
opacity: 0;
transform: translateX(1em);
}
to {
opacity: 1;
transform: none;
}
}
#logo {
display: inline-grid;
align-items: center;
grid-template-columns: auto 1fr;
gap: 0.6rem 0.4rem;
margin-right: 1rem;
h4 {
letter-spacing: 0.06rem;
word-spacing: 0.12rem;
}
h5 {
font-weight: 400;
}
#main_logo {
height: 1.6rem;
width: 1.6rem;
fill: rgba(var(--text-color), 1);
stroke: none;
}
}
textarea {
width: 100%;
max-width: 100%;
background: rgba(var(--text-color), 0.1);
border: none;
border-radius: 0.2rem;
resize: none;
font-size: 1rem;
line-height: 1.6;
padding: 0.8rem;
}
.input {
display: flex;
width: 100%;
align-items: center;
position: relative;
padding: 0.8em;
margin-bottom: 1.5em;
border-radius: 0.2rem;
background: rgba(var(--text-color), 0.1);
border: 0.1em solid transparent;
cursor: text;
&:last-of-type {
margin-bottom: 0;
}
&:focus-within {
border: 0.1em solid var(--accent-color);
}
.placeholder {
opacity: .6;
font-weight: 500;
font-size: 1em;
position: absolute;
transition: transform 0.3s ease;
transform-origin: left;
pointer-events: none;
will-change: contents;
text-transform: capitalize;
}
input {
flex: 1;
font-size: 1rem;
border: none;
background: transparent;
outline: none;
color: rgba(var(--text-color), 1);
}
}
.animate-label {
input {
transform: translateY(0.5em);
}
.placeholder {
transform: translateY(-60%) scale(0.7);
opacity: 1;
color: var(--accent-color);
}
}
*:empty + .empty-state {
display: grid;
}
.empty-state {
display: none;
place-items: center;
width: 100%;
svg {
stroke: rgba(var(--text-color), 0.8);
height: 12em;
width: 12em;
}
}
.container-header {
display: flex;
align-items: center;
flex-direction: row;
width: 100%;
padding: 1rem 0;
h2 {
flex: 1;
}
button {
align-self: center;
}
}
.btn {
background: var(--accent-color);
color: rgba(var(--foreground-color), 1);
padding: 0.4em 1em;
}
.back-arrow {
stroke: rgba(var(--text-color), 1);
stroke-width: 6;
fill: none;
height: 2rem;
padding: 0.5rem 0.5rem 0.5rem 0;
cursor: pointer;
}
.card {
border-radius: 0.6rem;
padding: 1.5em;
background: rgba(var(--foreground-color), 1);
}
.solid-background {
background: rgba(var(--foreground-color), 1) !important;
}
form {
width: 100%;
}
.popup-container {
display: grid;
position: fixed;
top: 0;
bottom: 0;
left: 0;
right: 0;
place-items: center;
background: rgba($color: #000000, $alpha: 0.4);
z-index: 10;
transition: opacity 0.3s ease;
.popup {
flex-direction: column;
align-self: flex-end;
align-items: flex-start;
flex-wrap: wrap;
width: 100%;
border-radius: 0.5rem 0.5rem 0 0;
padding: 1.5rem;
position: relative;
display: flex;
background: rgba(var(--foreground-color), 1);
transform: translateY(100%);
transition: transform 0.3s;
box-shadow: 0 2rem 2rem rgba($color: #000000, $alpha: 0.24);
overflow-y: auto;
h5 {
margin: 0.5rem 0;
}
button:first-of-type {
margin-left: auto;
}
.container-header {
display: flex;
align-items: center;
padding: 0;
margin-bottom: 1rem;
h4 {
flex: 1;
}
button {
width: auto;
}
.icon {
cursor: pointer;
padding-right: 0.4rem;
margin-right: 0.3rem;
stroke-width: 8;
}
}
p {
margin-bottom: 1.5rem !important;
}
}
}
#confirmation,
#prompt {
flex-direction: column;
p {
margin: 1rem;
}
h4 {
font-weight: 500;
margin-bottom: 1.5rem;
}
.input {
margin-bottom: 1rem;
}
.btns {
display: flex;
justify-content: right;
width: 100%;
button {
background: none;
}
button:first-of-type {
margin-right: 0.6em;
}
}
}
.refresh {
margin-top: 0.6em;
margin-bottom: 1em;
}
#sign_in_popup {
h3 {
margin-top: 2rem;
}
h4 {
font-weight: 500;
margin-bottom: 3rem;
}
button {
margin: 1rem 0;
}
p {
margin-top: 1rem;
margin-bottom: 0 !important;
}
.input {
background: rgba(var(--text-color), 0.1);
}
}
.primary-btn {
background: var(--accent-color);
justify-content: center;
color: rgba(var(--foreground-color), 1);
}
#main_header {
align-items: center;
padding: 1rem;
justify-content: space-between;
}
#display_balance {
.icon {
height: 1.4rem;
width: 1.4rem;
padding: 0.3rem;
stroke-width: 10;
cursor: pointer;
}
}
.icon {
height: 1.2rem;
width: 1.2rem;
fill: none;
stroke: rgba(var(--text-color), 0.8);
stroke-width: 6;
overflow: visible;
stroke-linecap: round;
stroke-linejoin: round;
}
#navbar {
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-evenly;
position: fixed;
left: 0;
right: 0;
bottom: 0;
top: auto;
border-top: solid 1px rgba(var(--text-color), 0.2);
border-right: none;
z-index: 3;
background: rgba(var(--foreground-color), 1);
.navbar-item {
position: relative;
text-align: center;
cursor: pointer;
padding: 0.3em;
margin: 0.3em;
border-radius: 0.4em;
color: rgba(var(--text-color), 0.8);
font-size: 0.8em;
text-transform: capitalize;
width: 100%;
font-weight: 600;
h5 {
margin-top: 0.4em;
}
}
.active {
color: var(--accent-color);
.icon {
stroke: var(--accent-color);
}
}
}
.banking {
stroke-width: 4;
}
#home_page {
padding: 1rem 0 4rem 0;
.left {
h4 {
padding: 0 1.5rem;
}
}
sm-carousel::part(carousel) {
padding: 0 1.5rem;
}
p {
margin-bottom: 3rem;
}
.user-panel{
margin: 0 1.5rem;
}
}
.user-panel {
position: relative;
padding: 1.5rem;
border-radius: 0.6rem;
background: radial-gradient(circle at top left, #EF6C00 20%, #C51162 30%, #4A148C 40%, #251f44);
box-shadow: 0 0.1rem 0.1rem #00000020, 0 2rem 1rem -1rem #00000040;
color: rgba(var(--foreground-color), 1);
align-self: flex-start;
.icon {
stroke: rgba(var(--foreground-color), 1);
}
.copy-row {
margin-bottom: 1.5rem;
text-shadow: 0.1rem 0.1rem 0.1rem #000000;
}
.grid {
margin-top: 0.5rem;
grid-template-columns: 1fr 1fr;
h5 {
font-weight: 500;
color: rgba(var(--foreground-color), 0.8);
}
}
}
.user-type {
font-weight: 500;
color: rgba(var(--foreground-color), 0.9);
}
.options-tab {
margin: 1rem 0;
.option {
position: relative;
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
border-radius: 0.4rem;
margin-right: 1rem;
margin-bottom: 1rem;
width: 5rem;
min-width: 5rem;
text-transform: capitalize;
transition: transform 0.3s;
cursor: pointer;
.icon {
height: 3rem;
width: 3rem;
padding: 0.8rem;
border-radius: 4rem;
margin-bottom: 0.5rem;
stroke: rgba(var(--foreground-color), 1);
}
h4 {
font-size: 0.9rem;
font-weight: 500;
}
&:active {
transform: scale(0.95);
}
&:nth-of-type(1) {
.icon {
background: linear-gradient(135deg, #D32F2F 50%, #B71C1C 50%);
}
}
&:nth-of-type(2) {
.icon {
background: linear-gradient(135deg, #7B1FA2 50%, #4A148C 50%);
}
}
&:nth-of-type(3) {
.icon {
background: linear-gradient(135deg, #1976D2 50%, #0D47A1 50%);
}
}
&:nth-of-type(4) {
.icon {
background: linear-gradient(135deg, #388E3C 50%, #1B5E20 50%);
}
}
&:nth-of-type(5) {
.icon {
background: linear-gradient(135deg, #F57C00 50%, #E65100 50%);
}
}
}
}
.notification-dot::after {
content: '';
position: absolute;
z-index: 1;
top: 0;
right: 0;
height: 0.6em;
width: 0.6em;
background-color: #E53935;
border-radius: 0.4em;
transition: transform 0.3s;
}
.shrink.notification-dot::after {
transform: scale(0);
}
#deposit,
#withdraw {
.container-header {
background: linear-gradient(rgba(var(--foreground-color), 1) 90%, transparent);
}
}
sm-tab-header {
position: sticky;
top: 0;
background: rgba(var(--foreground-color), 1);
z-index: 2;
margin-bottom: 1rem;
border-bottom: solid 1px rgba(var(--text-color), 0.2);
}
sm-tab::part(tab){
padding: 0.8rem 0.4rem;
text-transform: uppercase;
}
sm-panel{
width: 100%;
}
.request {
display: inline-flex;
flex-direction: column;
padding: 1.5em;
border-radius: 0.4em;
border: solid 1px rgba(var(--text-color), 0.2);
h5 {
margin-bottom: 0.2rem;
text-transform: capitalize;
}
h3,
h4 {
margin-bottom: 1.5rem;
}
h4:last-of-type {
margin-bottom: 0;
}
.action {
align-self: flex-end;
}
.amount {
font-size: 1.4em;
}
button {
width: auto;
align-self: flex-end;
margin-top: 1.5rem;
margin-bottom: 0;
}
.copy-row {
margin-bottom: 1.5rem;
}
.flex {
align-items: center;
justify-content: flex-end;
margin-top: 1.5rem;
h5 {
margin: 0;
}
button {
margin: 0;
}
}
}
.deposited {
color: #007732;
&::before {
content: '+ ';
}
}
.decline-request {
margin-right: 0.5rem !important;
}
.withdrawn {
color: #d43125;
&::before {
content: '- ';
}
}
.container {
display: grid;
gap: 1em;
width: 100%;
grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
}
.page {
padding: 1rem 1.5rem;
padding-bottom: 4rem;
.container-header {
display: grid;
grid-template-columns: 1fr auto;
grid-template-areas: '. .'
'search search';
gap: 1rem;
top: 0;
background: rgba(var(--foreground-color), 1);
will-change: auto;
z-index: 2;
.search {
grid-area: search;
input {
padding: 1em;
border: none;
width: 100%;
background: var(--dark-shade);
font-size: 1rem;
font-weight: 500;
color: rgba(var(--text-color), 1);
border-radius: 0.2em;
&:focus {
outline: none;
background: rgba(var(--text-color-light), 0.2);
}
}
}
}
}
.copy-row {
display: grid;
grid-template-columns: 1fr auto;
align-items: center;
gap: 0.5rem;
h4 {
margin-bottom: 0;
}
.icon {
cursor: pointer;
padding: 0.4rem;
height: 1.8rem;
width: 1.8rem;
}
.copy {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
}
.time {
margin-bottom: 1.5rem !important;
font-weight: 500;
}
#report_popup {
width: 32rem;
}
#profile_page {
display: flex;
flex-direction: column;
button {
align-self: flex-start;
}
}
.complaint {
display: grid;
gap: 1.5rem 0;
.complaint-actions {
align-items: center;
margin: 1.5rem 0 0 0;
}
.processed {
color: #007732;
}
.unprocessed {
color: #d43125;
}
.processed,
.unprocessed {
margin-bottom: 1.5rem;
}
button {
.icon {
padding: 0.2rem;
margin-right: 0.5rem;
stroke: var(--accent-color);
stroke-width: 8;
}
}
}
.complaints-container {
padding-top: 1.5rem;
display: grid;
align-items: flex-start;
gap: 1.5rem;
}
#helpline_page {
sm-select {
margin-bottom: 1.5rem;
}
}
.complaint-placeholder {
animation: pulse infinite 0.6s alternate;
h4,
h5 {
border-radius: 0.2rem;
}
h5 {
background: rgba(var(--text-color), 0.1);
padding: 0.5rem 0.6rem;
}
h4 {
background: rgba(var(--text-color), 0.2);
padding: 0.8rem 0.8rem;
}
.demo-btn {
padding: 0.8rem 3rem;
}
}
@keyframes pulse {
from {
opacity: 0.4;
}
to {
opacity: 1;
}
}
#main_loader {
box-shadow: none;
background: none;
text-align: center;
align-items: center;
flex-direction: column;
sm-button {
margin-left: 0;
margin-top: 1.5rem;
}
svg {
height: 2rem;
width: 2rem;
stroke: var(--accent-color);
stroke-width: 6;
fill: none;
overflow: visible;
stroke-linecap: round;
stroke-dashoffset: 210;
stroke-dasharray: 210;
justify-self: center;
align-self: center;
margin-bottom: 2rem;
}
h3 {
width: 100%;
text-transform: uppercase;
font-weight: 400;
word-spacing: 0.16em;
}
}
#upi_txId_section{
.copy-row{
margin-bottom: 1.5rem;
}
}
#send_amount_to_deposit{
margin-bottom: 0 !important;
}
@media only screen and (max-width: 640px) {
#home_page, #deposit{
display: grid;
gap: 1.5rem;
grid-template-areas: '.''left';
grid-template-columns: minmax(0, 1fr);
align-items: flex-start;
.left {
grid-area: left;
}
}
sm-select {
width: 100%;
}
}
@media only screen and (min-width: 640px) {
body {
padding: 0 2rem;
margin-left: 6rem;
}
.popup-container {
.popup {
transform: translateY(0) scale(0.96);
width: 24rem;
align-self: center;
border-radius: 0.4rem;
height: auto;
}
}
#confirmation {
width: 24rem;
}
#navbar {
justify-content: center;
flex-direction: column;
align-items: stretch;
left: 0;
bottom: 0;
top: 0;
right: auto;
width: 6rem;
border-top: none;
border-right: solid 1px rgba(var(--text-color), 0.2);
.navbar-item {
width: auto;
padding: 1.4em 0;
margin: 0.6em;
.icon {
height: 1.4rem;
width: 1.4rem;
}
&:hover {
.icon {
stroke: rgba(var(--text-color), 1);
}
h5 {
color: rgba(var(--text-color), 1);
}
}
&.active:hover {
.icon {
stroke: var(--accent-color);
}
h5 {
color: var(--accent-color);
}
}
}
}
.page {
padding-bottom: 2em;
}
#sign_in_popup {
width: 24rem;
}
#profile_page {
.copy-row {
display: inline-flex;
}
}
#home_page, #deposit {
display: grid;
gap: 1.5rem;
grid-template-columns: minmax(0, 1fr) 24rem;
}
}
@media only screen and (min-width: 800px) {
.complaint {
gap: 0 1.5rem;
grid-template-columns: 1fr 1fr;
grid-template-areas: '. . ''header header';
.complaint-actions {
grid-area: header;
}
.left {
border-right: 1px solid rgba(var(--text-color), 0.2);
}
.left {
padding-right: 1.5rem;
}
.right {
display: flex;
justify-content: center;
flex-direction: column;
}
}
.user-panel{
position: sticky;
top: 1.5rem;
}
}
@media only screen and (min-width: 1920px) {
body {
font-size: 24px;
}
}
@media only screen and (min-width: 2048px) {
body {
font-size: 24px;
}
}
@media only screen and (max-width: 320px) {
body {
font-size: 14px;
}
}
@media (prefers-color-scheme: dark) {
:root {
--text-color: 238, 238, 238;
--text-color-light: 170, 170, 170;
--foreground-color: 26, 26, 26;
--background-color: #111;
--dark-shade: #1a1a1a;
}
}
@media (prefers-color-scheme: light) {
:root {
--text-color: 17, 17, 17;
--text-color-light: 85, 85, 85;
--foreground-color: 255, 255, 255;
--background-color: #e8e8e8;
--dark-shade: #dadada;
}
}
@media (prefers-color-scheme: no-preference) {
:root {
--text-color: 17, 17, 17;
--text-color-light: 85, 85, 85;
--foreground-color: 255, 255, 255;
--background-color: #e8e8e8;
--dark-shade: #dadada;
}
}
@media (any-hover: hover) {}