* { box-sizing: border-box; padding: 0; margin: 0; font-family: 'Roboto', sans-serif; } :root { scroll-behavior: smooth; } body { --accent-color: #2237CD; --text-color: 17, 17, 17; --text-color-light: 85, 85, 85; --foreground-color: 255, 255, 255; --background-color: #e8e8e8; --dark-shade: #dadada; background: linear-gradient(rgba(var(--foreground-color), 0.1), rgba(var(--foreground-color), 0.3)),url(back.svg) no-repeat fixed; color: rgba(var(--text-color), 1); font-size: 16px; background-size: cover; } 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); } strong{ font-weight: 500; } 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 { opacity: 0.7; } .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 1.2rem; 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; } *: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; } #confirmation, #prompt { flex-direction: column; p { margin: 1rem; } h4 { font-weight: 500; margin-bottom: 1.5rem; } .flex { sm-button:first-of-type { margin-right: 0.6em; margin-left: auto; } } } .refresh { margin-top: 0.6em; margin-bottom: 1em; } sm-popup{ .illustration{ position: relative; height: 4rem; width: 4rem; padding: 1rem; stroke: var(--accent-color); margin-bottom: 1rem; border-radius: 5rem; background: rgba(var(--text-color), 0.06); } sm-input:not(:last-of-type) { margin-bottom: 1rem; } p{ margin-block-end: 1rem; } .action{ h4{ padding: 0.5rem 1rem; font-weight: 500; } } h5:not(.tag){ margin-bottom: 0.4rem; margin-top: 1rem; } } .popup-header{ padding: 1.5rem; padding-bottom: 0; display: flex; align-items: center; width: 100%; .icon{ margin-right: 1rem; padding: 0.2rem; stroke-width: 10; cursor: pointer; } button{ width: auto; margin-left: auto; } } details, summary{ margin-bottom: 1rem; } details{ p{ border-radius: 0.2rem; padding: 0.5rem 1rem; background: rgba(var(--text-color), 0.06); margin-bottom: 0; } } #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; } } .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 { gap: 1rem; grid-auto-flow: row; .balance{ width: 100%; } .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 { padding: 1.5rem 0; width: auto; border-radius: 0.6rem; h3, h4, p { padding: 0 1.5rem; } h3{ font-size: 2rem; margin-bottom: 1rem; } } .user-panel{ margin: 0 1.5rem; } } .user-panel { position: relative; padding: 1.5rem; border-radius: 0.6rem; background: linear-gradient(135deg, var(--accent-color), #2F2B76); color: rgba(var(--foreground-color), 1); box-shadow: 0 0.1rem 0.1rem #00000010, 0 1rem 1rem -1rem #00000010; align-self: flex-start; .icon{ stroke: rgba(var(--foreground-color), 1); } .copy-row { margin-bottom: 1rem; padding-bottom: 1rem; border-bottom: solid 1px rgba(var(--foreground-color), 0.3); } sm-button{ --text-color: rgba(var(--foreground-color), 1); background: rgba(var(--foreground-color), 0.2); border-radius: 2rem; } .grid { gap: 1.5rem; grid-template-columns: 1fr 1fr; margin-top: 1rem; h5 { font-weight: 500; } h4{ font-size: 1.2rem; } P{ font-size: 0.8rem; opacity: 0.9; color: rgba(var(--foreground-color), 1); margin-bottom: 0 !important; max-width: 30ch; } } } .balance{ display: grid; gap: 0 1rem; } .user-type { font-weight: 500; } .options-tab { margin: 1rem 0; & > .grid{ min-width: 100vw; padding: 0 1.5rem; grid-auto-flow: column; gap: 0.2rem; } .option { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; border-radius: 0.4rem; margin-bottom: 1rem; width: 5rem; min-width: 5rem; text-transform: capitalize; transition: transform 0.3s; -webkit-tap-highlight-color: transparent; cursor: pointer; .icon { height: 3rem; width: 3rem; padding: 0.8rem; stroke: var(--accent-color); } h4 { font-size: 0.9rem; font-weight: 500; } &:active { transform: scale(0.95); } } } .request-icon{ transform: rotate(180deg); } .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: capitalize; } 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; } .decline-request { margin-right: 0.5rem !important; } .withdrawn { color: #d43125; } .container { display: grid; gap: 1em; width: 100%; grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr)); } .page { padding: 1rem 1.5rem; padding-bottom: 5rem; .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; width: auto; 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 { text-align: center; place-content: center; height: 100vh; width: 100vw; position: fixed; left: 0; sm-button { margin-left: 0; margin-top: 1rem; } 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%; font-weight: 400; word-spacing: 0.16em; } } #upi_txId_section{ .copy-row{ margin-bottom: 1.5rem; } } #send_amount_to_deposit{ margin-bottom: 0 !important; } @keyframes popup{ 0%{ stroke-dashoffset: 50; transform: translateY(4rem) scale(0.2, 0.6); } 40%{ transform: translateY(0) scale(0.2); } 41%{ transform: translateY(0) scale(0.2); } 50%{ stroke-dashoffset: 50; transform: translateY(0) scale(1); } 100%{ stroke-dashoffset: 0; } } #transaction_result{ z-index: 12; &::part(popup){ background-image: url(card-back.svg); background-size: cover; background-position-y: -3rem; background-repeat: no-repeat; } .copy-row{ grid-template-areas: 'label label' '. .'; margin-top: 1rem; gap: 0 1rem; h4{ font-weight: 500; } } h5{ grid-area: label; color: rgba(var(--text-color), 0.7); } h4, h5, p{ text-align: center; } & > h4{ font-size: 1.2rem; margin-top: 6rem; margin-bottom: 0.5rem; } } #success_svg, #failure_svg{ height: 5rem; width: 5rem; stroke-width: 4; align-self: center; stroke: none; stroke-dasharray: 50; fill: rgba(var(--foreground-color), 1); animation: popup 2s forwards cubic-bezier(0.175, 0.885, 0.32, 1.275); } #success_svg{ polyline{ fill: none; stroke: #00C853 ; } } #failure_svg{ line{ stroke: #EF5350; } } .rupee-symbol{ height: 1rem; width: 1rem; fill: rgba(var(--text-color), 0.5); } #deposit_rupee{ .copy-row{ margin-bottom: 1rem; } } .activity-container{ display: grid; gap: 1rem; } .activity{ display: grid; background: rgba(var(--text-color), 0.06); border-radius: 0.6rem; padding: 1rem 1.2rem; gap: 0 1rem; grid-template-columns: auto 1fr auto; grid-template-areas: 'icon type amount' 'icon receiver time'; max-width: 70ch; align-items: center; cursor: pointer; .icon{ grid-area: icon; height: 3rem; width: 3rem; padding: 0.8rem; background: rgba(var(--text-color), 0.06); border-radius: 2rem; } .activity-type{ grid-area: type; text-transform: capitalize; font-weight: 400; font-size: 0.8rem; } .activity-receiver{ grid-area: receiver; font-weight: 500; font-size: 0.9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .activity-amount{ text-align: right; grid-area: amount; } .activity-time{ text-align: right; grid-area: time; color: rgba(var(--text-color), 0.7); font-weight: 500; } } .select{ max-width: 50ch; position: relative; display: flex; width: 100%; padding: 0.8rem 1rem; border-radius: 0.3rem; background: rgba(var(--text-color), 0.1); align-items: center; cursor: pointer; &:first-of-type:not(:last-of-type){ border-radius: 0.3rem 0.3rem 0 0; } & + &{ margin-top: 0; border-radius: 0 0 0.3rem 0.3rem; border-top: solid 1px rgba(var(--text-color), 0.16); } input[type="radio"]{ display: none; } input:checked ~ .radio .outer-ring{ stroke: var(--accent-color); } input:checked ~ .radio .inner-disc{ transform: none; } .radio{ width: 1.2rem; height: 1.2rem; fill: none; overflow: visible; margin-right: 0.6rem; .outer-ring{ stroke-width: 8; stroke: rgba(var(--text-color), 0.5); } .inner-disc{ transform-origin: center; fill: var(--accent-color); transform: scale(0); transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); } } .tag{ opacity: 0.6; font-weight: 500; margin-left: auto; } h4{ font-weight: 400; } .outer{ position: absolute; left: 0; right: 0; top: 0; bottom: 0; pointer-events: none; } } .add-upi{ margin-top: 0.4rem; justify-self: flex-start; width: max-content; } @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); .left { grid-area: left; background: rgba(var(--text-color), 0.06); } } sm-select { width: 100%; } } @media only screen and (min-width: 640px) { body { padding: 0 2rem; margin-left: 6rem; } sm-popup{ background: rgba(var(--foreground-color), 1); } sm-popup::part(popup){ width: 24rem; } #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 { border-radius: 0.5rem; width: auto; padding: 0.5rem 0; margin: 0.5rem 0.6rem; .icon { height: 1.4rem; width: 1.4rem; } &:hover { background: rgba(var(--foreground-color), 0.2); } &.active{ background: rgba(var(--foreground-color), 1); color: var(--accent-color); .icon{ stroke: var(--accent-color); } } } } .page { padding-bottom: 2rem; } #sign_in_popup { width: 24rem; } .options-tab{ & > .grid{ gap: 1rem; min-width: auto; } .grid:first-of-type{ padding-right: 0; } .grid:last-of-type{ padding-left: 0; } } #settings_page{ .copy-row{ display: inline-grid; } } } @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; } #home_page, #deposit { display: grid; gap: 1.5rem; grid-template-columns: minmax(0, 1fr) 24rem; } } @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) { .option:hover{ background: rgba(var(--text-color), 0.1); } }