Tweak account create layout for small and large screens (#306)

This commit is contained in:
Leendert de Borst
2024-10-18 11:46:14 +02:00
parent 3ff418945c
commit 26580f72ca
9 changed files with 287 additions and 373 deletions

View File

@@ -4,14 +4,14 @@
@inject JsInteropService JsInteropService
<div class="w-full max-w-md mx-auto">
@if (isLoading)
@if (isLoading)
{
<div class="flex justify-center items-center h-64">
<div class="absolute inset-0 flex justify-center items-center z-10">
<div class="animate-spin rounded-full h-16 w-16 border-t-2 border-b-2 border-primary-500"></div>
</div>
}
<div class="@(isLoading ? "opacity-0" : "opacity-100 transition-opacity duration-300") w-full">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg p-6 mb-6">
<div class="@(isLoading ? "invisible opacity-0" : "opacity-100") transition-opacity duration-300 w-full">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg lg:shadow-none p-6 mb-6">
<div class="flex items-start mb-4">
<div class="flex-shrink-0">
<img class="h-10 w-10 rounded-full" src="/img/avatar.webp" alt="AliasVault Assistant">

View File

@@ -1,7 +1,7 @@
@using AliasVault.Client.Auth.Pages.Setup.Components
<div class="w-full max-w-md mx-auto">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg p-6 mb-6">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg lg:shadow-none p-6 mb-6">
<div class="flex items-start mb-4">
<div class="flex-shrink-0">
<img class="h-10 w-10 rounded-full" src="/img/avatar.webp" alt="AliasVault Assistant">

View File

@@ -3,12 +3,12 @@
<div class="w-full max-w-md mx-auto">
@if (isLoading)
{
<div class="flex justify-center items-center h-64">
<div class="absolute inset-0 flex justify-center items-center z-10">
<div class="animate-spin rounded-full h-16 w-16 border-t-2 border-b-2 border-primary-500"></div>
</div>
}
<div class="@(isLoading ? "opacity-0" : "opacity-100 transition-opacity duration-300") w-full">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg p-6 mb-6">
<div class="@(isLoading ? "invisible opacity-0" : "opacity-100") transition-opacity duration-300 w-full">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg lg:shadow-none p-6 mb-6">
<div class="flex items-start mb-4">
<div class="flex-shrink-0">
<img class="h-10 w-10 rounded-full" src="/img/avatar.webp" alt="AliasVault Assistant">

View File

@@ -6,12 +6,12 @@
<div class="w-full max-w-md mx-auto">
@if (isLoading)
{
<div class="flex justify-center items-center h-64">
<div class="absolute inset-0 flex justify-center items-center z-10">
<div class="animate-spin rounded-full h-16 w-16 border-t-2 border-b-2 border-primary-500"></div>
</div>
}
<div class="@(isLoading ? "opacity-0" : "opacity-100 transition-opacity duration-300") w-full">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg p-6 mb-6">
<div class="@(isLoading ? "invisible opacity-0" : "opacity-100") transition-opacity duration-300 w-full">
<div class="bg-white dark:bg-gray-800 rounded-lg shadow-lg lg:shadow-none p-6 mb-6">
<div class="flex items-start mb-4">
<div class="flex-shrink-0">
<img class="h-10 w-10 rounded-full" src="/img/avatar.webp" alt="AliasVault Assistant">

View File

@@ -1,5 +1,5 @@
<div class="w-full">
<h2 class="text-2xl font-bold text-gray-900 dark:text-white mb-4 text-center">Welcome to AliasVault</h2>
<div class="w-full max-w-md mx-auto">
<h2 class="mt-24 text-2xl font-bold text-gray-900 dark:text-white mb-4 text-center">Welcome to AliasVault</h2>
<p class="text-gray-600 dark:text-gray-400 mb-4 text-center">
AliasVault is a secure and private way to manage your online identities.
Let's get you set up with your new vault.

View File

@@ -10,70 +10,70 @@
@using AliasVault.Cryptography.Client
@using SecureRemotePassword
<div class="flex min-h-screen bg-gray-100 dark:bg-gray-900">
<div class="w-full max-w-md mx-auto flex flex-col @(currentStep == SetupStep.Welcome ? "justify-center" : "pt-8")">
<div>
@switch (currentStep)
{
case SetupStep.Welcome:
<WelcomeStep />
break;
case SetupStep.Purpose:
<PurposeStep
Purpose="@setupData.Purpose"
OnPurposeChange="@((string purpose) => { setupData.Purpose = purpose; StateHasChanged(); })"
IsPurposeSelected="@(!string.IsNullOrWhiteSpace(setupData.Purpose))" />
break;
case SetupStep.PurposeInstructions:
<PurposeInstructionsStep Purpose="@setupData.Purpose" />
break;
case SetupStep.UserInfo:
<UsernameStep
DefaultUsername="@setupData.Username"
OnUsernameChange="@((string username) => { setupData.Username = username; StateHasChanged(); })" />
break;
case SetupStep.Password:
<PasswordStep
Username="@setupData.Username"
OnPasswordChange="@((string pwd) => { setupData.Password = pwd; StateHasChanged(); })" />
break;
}
</div>
<div class="fixed bottom-0 left-0 right-0 p-8 bg-gray-100 dark:bg-gray-900 border-t border-gray-200 dark:border-gray-700">
<div class="flex flex-col lg:flex-row lg:justify-between">
<div class="lg:flex-grow">
@if (currentStep != SetupStep.Welcome)
{
<button @onclick="GoBack" class="w-full lg:w-auto py-3 px-4 bg-gray-200 hover:bg-gray-300 dark:bg-gray-700 dark:hover:bg-gray-gray-800 text-gray-800 dark:text-white font-semibold rounded-lg transition duration-300 ease-in-out mb-4 lg:mb-0">
Go Back
</button>
}
</div>
<div class="lg:flex-shrink-0">
@if (currentStep == SetupStep.Password && !string.IsNullOrWhiteSpace(setupData.Password))
{
<button @onclick="CompleteSetup"
class="w-full lg:w-auto py-3 px-4 bg-green-600 hover:bg-green-700 text-white font-semibold rounded-lg transition duration-300 ease-in-out">
Create Account
</button>
}
else
{
<button @onclick="GoNext"
class="w-full lg:w-auto py-3 px-4 bg-primary-600 hover:bg-primary-700 text-white font-semibold rounded-lg transition duration-300 ease-in-out @(isNextEnabled ? "" : "opacity-50 cursor-not-allowed")"
disabled="@(!isNextEnabled)">
Continue
</button>
}
</div>
<div class="min-h-screen bg-gray-100 dark:bg-gray-900 flex items-center justify-center">
<div class="w-full max-w-md mx-auto lg:max-w-xl lg:bg-white lg:dark:bg-gray-800 lg:shadow-xl lg:rounded-lg lg:overflow-hidden">
<div class="flex flex-col min-h-screen lg:min-h-0">
<div class="flex-grow p-8 pt-16 lg:pt-8">
@if (currentStep != SetupStep.Welcome)
{
<button @onclick="GoBack" class="absolute top-4 lg:top-0 left-4 lg:left-auto lg:relative text-gray-600 hover:text-gray-800 dark:text-gray-400 dark:hover:text-gray-200">
<svg class="w-6 h-6" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10 19l-7-7m0 0l7-7m-7 7h18"></path>
</svg>
</button>
}
@switch (currentStep)
{
case SetupStep.Welcome:
<WelcomeStep />
break;
case SetupStep.Purpose:
<PurposeStep
Purpose="@setupData.Purpose"
OnPurposeChange="@((string purpose) => { setupData.Purpose = purpose; StateHasChanged(); })"
IsPurposeSelected="@(!string.IsNullOrWhiteSpace(setupData.Purpose))" />
break;
case SetupStep.PurposeInstructions:
<PurposeInstructionsStep Purpose="@setupData.Purpose" />
break;
case SetupStep.UserInfo:
<UsernameStep
DefaultUsername="@setupData.Username"
OnUsernameChange="@((string username) => { setupData.Username = username; StateHasChanged(); })" />
break;
case SetupStep.Password:
<PasswordStep
Username="@setupData.Username"
OnPasswordChange="@((string pwd) => { setupData.Password = pwd; StateHasChanged(); })" />
break;
}
</div>
<div class="p-8 bg-gray-100 dark:bg-gray-900 border-t border-gray-200 dark:border-gray-700 lg:bg-transparent lg:dark:bg-transparent lg:border-0">
@if (currentStep == SetupStep.Password && !string.IsNullOrWhiteSpace(setupData.Password))
{
<button @onclick="CompleteSetup"
class="w-full py-3 px-4 bg-green-600 hover:bg-green-700 text-white font-semibold rounded-lg transition duration-300 ease-in-out">
Create Account
</button>
}
else
{
<button @onclick="GoNext"
class="w-full py-3 px-4 bg-primary-600 hover:bg-primary-700 text-white font-semibold rounded-lg transition duration-300 ease-in-out @(isNextEnabled ? "" : "opacity-50 cursor-not-allowed")"
disabled="@(!isNextEnabled)">
Continue
</button>
}
</div>
</div>
<button @onclick="CancelSetup" class="absolute top-4 right-4 text-gray-500 hover:text-gray-700 dark:text-gray-400 dark:hover:text-gray-200">
<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"></path>
</svg>
</button>
</div>
<button @onclick="CancelSetup" class="absolute top-4 right-4 text-gray-500 hover:text-gray-700 dark:text-gray-400 dark:hover:text-gray-200">
<svg class="w-8 h-8" fill="none" stroke="currentColor" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12"></path>
</svg>
</button>
</div>
<FullScreenLoadingIndicator @ref="LoadingIndicator"/>

View File

@@ -4,7 +4,7 @@
@layout Auth.Layout.EmptyLayout
@attribute [AllowAnonymous]
<div class="flex lg:min-h-screen bg-gray-100 dark:bg-gray-900">
<div class="flex lg:min-h-screen bg-gray-50 dark:bg-gray-900">
<div class="w-full max-w-7xl mx-auto flex flex-col lg:flex-row">
<!-- Left column with image placeholder -->
<div class="hidden lg:flex lg:w-1/2 items-center justify-center p-8">
@@ -29,7 +29,7 @@
Create new vault
</button>
<button @onclick="NavigateToLogin" class="w-full py-3 px-4 bg-gray-200 hover:bg-gray-300 dark:bg-gray-700 dark:hover:bg-gray-800 text-gray-800 dark:text-white font-semibold rounded-lg transition duration-300 ease-in-out">
Log in to existing vault
Log in with existing account
</button>
</div>
</div>

View File

@@ -1,7 +1,7 @@
@inject NavigationManager NavigationManager
@implements IDisposable
<footer class="relative lg:fixed bottom-0 left-0 right-0 bg-white dark:bg-gray-900 @(ShowBorder ? "border-t border-gray-200 dark:border-gray-700" : "")">
<footer class="relative lg:fixed bottom-0 left-0 right-0 dark:bg-gray-900 @(ShowBorder ? "border-t border-gray-200 dark:border-gray-700" : "")">
<div class="container mx-auto px-4 py-4">
<div class="flex flex-col lg:flex-row justify-between items-center">
<p class="text-sm text-center text-gray-500 mb-4 lg:mb-0">

View File

@@ -604,6 +604,10 @@ video {
visibility: visible;
}
.invisible {
visibility: hidden;
}
.static {
position: static;
}
@@ -634,6 +638,10 @@ video {
bottom: 0.25rem;
}
.bottom-0 {
bottom: 0px;
}
.bottom-1 {
bottom: 0.25rem;
}
@@ -642,6 +650,10 @@ video {
inset-inline-end: 0.25rem;
}
.left-0 {
left: 0px;
}
.right-0 {
right: 0px;
}
@@ -654,6 +666,10 @@ video {
right: 2.5rem;
}
.right-4 {
right: 1rem;
}
.top-12 {
top: 3rem;
}
@@ -662,30 +678,18 @@ video {
top: 5rem;
}
.bottom-0 {
bottom: 0px;
.top-4 {
top: 1rem;
}
.left-0 {
left: 0px;
.left-4 {
left: 1rem;
}
.top-0 {
top: 0px;
}
.top-1\/2 {
top: 50%;
}
.right-4 {
right: 1rem;
}
.top-4 {
top: 1rem;
}
.z-10 {
z-index: 10;
}
@@ -829,8 +833,8 @@ video {
margin-top: 2rem;
}
.mt-10 {
margin-top: 2.5rem;
.mt-24 {
margin-top: 6rem;
}
.line-clamp-2 {
@@ -880,6 +884,14 @@ video {
height: 3rem;
}
.h-16 {
height: 4rem;
}
.h-20 {
height: 5rem;
}
.h-3 {
height: 0.75rem;
}
@@ -896,6 +908,10 @@ video {
height: 1.5rem;
}
.h-64 {
height: 16rem;
}
.h-8 {
height: 2rem;
}
@@ -908,26 +924,6 @@ video {
height: 100%;
}
.h-64 {
height: 16rem;
}
.h-32 {
height: 8rem;
}
.h-24 {
height: 6rem;
}
.h-20 {
height: 5rem;
}
.h-16 {
height: 4rem;
}
.min-h-screen {
min-height: 100vh;
}
@@ -944,6 +940,14 @@ video {
width: 3rem;
}
.w-16 {
width: 4rem;
}
.w-20 {
width: 5rem;
}
.w-28 {
width: 7rem;
}
@@ -984,26 +988,14 @@ video {
width: 100%;
}
.w-32 {
width: 8rem;
}
.w-24 {
width: 6rem;
}
.w-20 {
width: 5rem;
}
.w-16 {
width: 4rem;
}
.min-w-full {
min-width: 100%;
}
.max-w-7xl {
max-width: 80rem;
}
.max-w-md {
max-width: 28rem;
}
@@ -1016,14 +1008,6 @@ video {
max-width: 36rem;
}
.max-w-4xl {
max-width: 56rem;
}
.max-w-7xl {
max-width: 80rem;
}
.flex-shrink-0 {
flex-shrink: 0;
}
@@ -1032,31 +1016,6 @@ video {
flex-grow: 1;
}
.origin-center {
transform-origin: center;
}
.-translate-y-1\/2 {
--tw-translate-y: -50%;
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.-skew-y-12 {
--tw-skew-y: -12deg;
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.skew-y-12 {
--tw-skew-y: 12deg;
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.scale-0 {
--tw-scale-x: 0;
--tw-scale-y: 0;
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.transform {
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
@@ -1309,6 +1268,10 @@ video {
border-bottom-width: 1px;
}
.border-b-2 {
border-bottom-width: 2px;
}
.border-l-0 {
border-left-width: 0px;
}
@@ -1321,14 +1284,15 @@ video {
border-top-width: 1px;
}
.border-b-2 {
border-bottom-width: 2px;
}
.border-t-2 {
border-top-width: 2px;
}
.border-blue-500 {
--tw-border-opacity: 1;
border-color: rgb(59 130 246 / var(--tw-border-opacity));
}
.border-blue-700 {
--tw-border-opacity: 1;
border-color: rgb(29 78 216 / var(--tw-border-opacity));
@@ -1369,14 +1333,9 @@ video {
border-color: rgb(214 131 56 / var(--tw-border-opacity));
}
.border-indigo-500 {
--tw-border-opacity: 1;
border-color: rgb(99 102 241 / var(--tw-border-opacity));
}
.border-blue-500 {
--tw-border-opacity: 1;
border-color: rgb(59 130 246 / var(--tw-border-opacity));
.bg-blue-100 {
--tw-bg-opacity: 1;
background-color: rgb(219 234 254 / var(--tw-bg-opacity));
}
.bg-blue-50 {
@@ -1519,26 +1478,6 @@ video {
background-color: rgb(254 252 232 / var(--tw-bg-opacity));
}
.bg-emerald-500 {
--tw-bg-opacity: 1;
background-color: rgb(16 185 129 / var(--tw-bg-opacity));
}
.bg-indigo-500 {
--tw-bg-opacity: 1;
background-color: rgb(99 102 241 / var(--tw-bg-opacity));
}
.bg-indigo-600 {
--tw-bg-opacity: 1;
background-color: rgb(79 70 229 / var(--tw-bg-opacity));
}
.bg-blue-100 {
--tw-bg-opacity: 1;
background-color: rgb(219 234 254 / var(--tw-bg-opacity));
}
.bg-opacity-50 {
--tw-bg-opacity: 0.5;
}
@@ -1577,6 +1516,10 @@ video {
padding: 0.625rem;
}
.p-3 {
padding: 0.75rem;
}
.p-4 {
padding: 1rem;
}
@@ -1593,10 +1536,6 @@ video {
padding: 2rem;
}
.p-3 {
padding: 0.75rem;
}
.px-2 {
padding-left: 0.5rem;
padding-right: 0.5rem;
@@ -1627,11 +1566,21 @@ video {
padding-right: 1.75rem;
}
.px-8 {
padding-left: 2rem;
padding-right: 2rem;
}
.py-1 {
padding-top: 0.25rem;
padding-bottom: 0.25rem;
}
.py-12 {
padding-top: 3rem;
padding-bottom: 3rem;
}
.py-2 {
padding-top: 0.5rem;
padding-bottom: 0.5rem;
@@ -1652,30 +1601,14 @@ video {
padding-bottom: 1rem;
}
.py-6 {
padding-top: 1.5rem;
padding-bottom: 1.5rem;
.pb-4 {
padding-bottom: 1rem;
}
.py-8 {
padding-top: 2rem;
.pb-8 {
padding-bottom: 2rem;
}
.px-8 {
padding-left: 2rem;
padding-right: 2rem;
}
.py-12 {
padding-top: 3rem;
padding-bottom: 3rem;
}
.pb-2 {
padding-bottom: 0.5rem;
}
.pr-10 {
padding-right: 2.5rem;
}
@@ -1696,6 +1629,10 @@ video {
padding-top: 0.5rem;
}
.pt-20 {
padding-top: 5rem;
}
.pt-4 {
padding-top: 1rem;
}
@@ -1708,12 +1645,20 @@ video {
padding-top: 2rem;
}
.pb-4 {
padding-bottom: 1rem;
.pt-24 {
padding-top: 6rem;
}
.pb-8 {
padding-bottom: 2rem;
.pt-10 {
padding-top: 2.5rem;
}
.pt-12 {
padding-top: 3rem;
}
.pt-14 {
padding-top: 3.5rem;
}
.text-left {
@@ -1746,6 +1691,16 @@ video {
line-height: 2.25rem;
}
.text-4xl {
font-size: 2.25rem;
line-height: 2.5rem;
}
.text-5xl {
font-size: 3rem;
line-height: 1;
}
.text-base {
font-size: 1rem;
line-height: 1.5rem;
@@ -1771,16 +1726,6 @@ video {
line-height: 1rem;
}
.text-4xl {
font-size: 2.25rem;
line-height: 2.5rem;
}
.text-5xl {
font-size: 3rem;
line-height: 1;
}
.font-bold {
font-weight: 700;
}
@@ -1926,14 +1871,26 @@ video {
color: rgb(255 255 255 / var(--tw-text-opacity));
}
.text-yellow-600 {
--tw-text-opacity: 1;
color: rgb(202 138 4 / var(--tw-text-opacity));
}
.text-yellow-800 {
--tw-text-opacity: 1;
color: rgb(133 77 14 / var(--tw-text-opacity));
}
.text-yellow-600 {
--tw-text-opacity: 1;
color: rgb(202 138 4 / var(--tw-text-opacity));
.opacity-0 {
opacity: 0;
}
.opacity-10 {
opacity: 0.1;
}
.opacity-100 {
opacity: 1;
}
.opacity-25 {
@@ -1948,14 +1905,6 @@ video {
opacity: 0.75;
}
.opacity-0 {
opacity: 0;
}
.opacity-100 {
opacity: 1;
}
.shadow {
--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
@@ -2004,18 +1953,6 @@ video {
transition-duration: 150ms;
}
.transition-all {
transition-property: all;
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
transition-duration: 150ms;
}
.transition-transform {
transition-property: transform;
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
transition-duration: 150ms;
}
.transition-opacity {
transition-property: opacity;
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
@@ -2034,18 +1971,10 @@ video {
transition-duration: 300ms;
}
.duration-500 {
transition-duration: 500ms;
}
.ease-in-out {
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.ease-out {
transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
.hover\:scale-105:hover {
--tw-scale-x: 1.05;
--tw-scale-y: 1.05;
@@ -2142,11 +2071,6 @@ video {
background-color: rgb(153 27 27 / var(--tw-bg-opacity));
}
.hover\:bg-indigo-700:hover {
--tw-bg-opacity: 1;
background-color: rgb(67 56 202 / var(--tw-bg-opacity));
}
.hover\:from-primary-600:hover {
--tw-gradient-from: #d68338 var(--tw-gradient-from-position);
--tw-gradient-to: rgb(214 131 56 / 0) var(--tw-gradient-to-position);
@@ -2172,6 +2096,11 @@ video {
color: rgb(107 114 128 / var(--tw-text-opacity));
}
.hover\:text-gray-700:hover {
--tw-text-opacity: 1;
color: rgb(55 65 81 / var(--tw-text-opacity));
}
.hover\:text-gray-900:hover {
--tw-text-opacity: 1;
color: rgb(17 24 39 / var(--tw-text-opacity));
@@ -2197,21 +2126,15 @@ video {
color: rgb(255 255 255 / var(--tw-text-opacity));
}
.hover\:text-gray-700:hover {
.hover\:text-gray-800:hover {
--tw-text-opacity: 1;
color: rgb(55 65 81 / var(--tw-text-opacity));
color: rgb(31 41 55 / var(--tw-text-opacity));
}
.hover\:underline:hover {
text-decoration-line: underline;
}
.hover\:shadow-2xl:hover {
--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.focus\:border-blue-500:focus {
--tw-border-opacity: 1;
border-color: rgb(59 130 246 / var(--tw-border-opacity));
@@ -2304,24 +2227,6 @@ video {
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.disabled\:cursor-not-allowed:disabled {
cursor: not-allowed;
}
.disabled\:opacity-50:disabled {
opacity: 0.5;
}
.group:hover .group-hover\:-skew-y-12 {
--tw-skew-y: -12deg;
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.group:hover .group-hover\:skew-y-12 {
--tw-skew-y: 12deg;
transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.dark\:divide-gray-600:is(.dark *) > :not([hidden]) ~ :not([hidden]) {
--tw-divide-opacity: 1;
border-color: rgb(75 85 99 / var(--tw-divide-opacity));
@@ -2371,16 +2276,16 @@ video {
border-color: rgb(234 179 8 / var(--tw-border-opacity));
}
.dark\:border-indigo-400:is(.dark *) {
--tw-border-opacity: 1;
border-color: rgb(129 140 248 / var(--tw-border-opacity));
}
.dark\:bg-blue-800:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(30 64 175 / var(--tw-bg-opacity));
}
.dark\:bg-blue-900:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(30 58 138 / var(--tw-bg-opacity));
}
.dark\:bg-gray-500:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(107 114 128 / var(--tw-bg-opacity));
@@ -2446,21 +2351,6 @@ video {
background-color: rgb(133 77 14 / var(--tw-bg-opacity));
}
.dark\:bg-emerald-600:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(5 150 105 / var(--tw-bg-opacity));
}
.dark\:bg-indigo-600:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(79 70 229 / var(--tw-bg-opacity));
}
.dark\:bg-blue-900:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(30 58 138 / var(--tw-bg-opacity));
}
.dark\:bg-opacity-80:is(.dark *) {
--tw-bg-opacity: 0.8;
}
@@ -2574,6 +2464,11 @@ video {
background-color: rgb(55 65 81 / var(--tw-bg-opacity));
}
.dark\:hover\:bg-gray-800:hover:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(31 41 55 / var(--tw-bg-opacity));
}
.dark\:hover\:bg-green-700:hover:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(21 128 61 / var(--tw-bg-opacity));
@@ -2594,11 +2489,6 @@ video {
background-color: rgb(185 28 28 / var(--tw-bg-opacity));
}
.dark\:hover\:bg-gray-800:hover:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(31 41 55 / var(--tw-bg-opacity));
}
.dark\:hover\:from-primary-500:hover:is(.dark *) {
--tw-gradient-from: #f49541 var(--tw-gradient-from-position);
--tw-gradient-to: rgb(244 149 65 / 0) var(--tw-gradient-to-position);
@@ -2614,6 +2504,11 @@ video {
color: rgb(191 219 254 / var(--tw-text-opacity));
}
.dark\:hover\:text-gray-200:hover:is(.dark *) {
--tw-text-opacity: 1;
color: rgb(229 231 235 / var(--tw-text-opacity));
}
.dark\:hover\:text-primary-500:hover:is(.dark *) {
--tw-text-opacity: 1;
color: rgb(244 149 65 / var(--tw-text-opacity));
@@ -2624,11 +2519,6 @@ video {
color: rgb(255 255 255 / var(--tw-text-opacity));
}
.dark\:hover\:text-gray-200:hover:is(.dark *) {
--tw-text-opacity: 1;
color: rgb(229 231 235 / var(--tw-text-opacity));
}
.dark\:focus\:border-blue-500:focus:is(.dark *) {
--tw-border-opacity: 1;
border-color: rgb(59 130 246 / var(--tw-border-opacity));
@@ -2774,10 +2664,6 @@ video {
}
@media (min-width: 768px) {
.md\:mb-0 {
margin-bottom: 0px;
}
.md\:ml-2 {
margin-left: 0.5rem;
}
@@ -2786,10 +2672,6 @@ video {
display: inline;
}
.md\:flex {
display: flex;
}
.md\:h-screen {
height: 100vh;
}
@@ -2798,10 +2680,6 @@ video {
width: 16rem;
}
.md\:w-1\/2 {
width: 50%;
}
.md\:grid-cols-2 {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
@@ -2814,28 +2692,11 @@ video {
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.md\:flex-row {
flex-direction: row;
}
.md\:items-center {
align-items: center;
}
.md\:justify-between {
justify-content: space-between;
}
.md\:space-x-2 > :not([hidden]) ~ :not([hidden]) {
--tw-space-x-reverse: 0;
margin-right: calc(0.5rem * var(--tw-space-x-reverse));
margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse)));
}
.md\:py-10 {
padding-top: 2.5rem;
padding-bottom: 2.5rem;
}
}
@media (min-width: 1024px) {
@@ -2843,8 +2704,20 @@ video {
position: fixed;
}
.lg\:absolute {
position: absolute;
.lg\:relative {
position: relative;
}
.lg\:-left-16 {
left: -4rem;
}
.lg\:left-auto {
left: auto;
}
.lg\:top-0 {
top: 0px;
}
.lg\:order-1 {
@@ -2859,8 +2732,8 @@ video {
grid-column: auto;
}
.lg\:mb-10 {
margin-bottom: 2.5rem;
.lg\:mb-0 {
margin-bottom: 0px;
}
.lg\:mr-8 {
@@ -2875,10 +2748,6 @@ video {
margin-top: 0px;
}
.lg\:mb-0 {
margin-bottom: 0px;
}
.lg\:block {
display: block;
}
@@ -2891,16 +2760,24 @@ video {
display: none;
}
.lg\:min-h-0 {
min-height: 0px;
}
.lg\:min-h-screen {
min-height: 100vh;
}
.lg\:w-1\/2 {
width: 50%;
}
.lg\:w-auto {
width: auto;
}
.lg\:w-1\/2 {
width: 50%;
.lg\:max-w-xl {
max-width: 36rem;
}
.lg\:flex-shrink-0 {
@@ -2923,17 +2800,59 @@ video {
gap: 1rem;
}
.lg\:pb-20 {
padding-bottom: 5rem;
.lg\:overflow-hidden {
overflow: hidden;
}
.lg\:pb-14 {
padding-bottom: 3.5rem;
.lg\:rounded-lg {
border-radius: 0.5rem;
}
.lg\:border-0 {
border-width: 0px;
}
.lg\:bg-transparent {
background-color: transparent;
}
.lg\:bg-white {
--tw-bg-opacity: 1;
background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}
.lg\:pb-16 {
padding-bottom: 4rem;
}
.lg\:pt-10 {
padding-top: 2.5rem;
}
.lg\:pt-8 {
padding-top: 2rem;
}
.lg\:shadow-none {
--tw-shadow: 0 0 #0000;
--tw-shadow-colored: 0 0 #0000;
box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.lg\:shadow-xl {
--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.lg\:dark\:bg-gray-800:is(.dark *) {
--tw-bg-opacity: 1;
background-color: rgb(31 41 55 / var(--tw-bg-opacity));
}
.lg\:dark\:bg-transparent:is(.dark *) {
background-color: transparent;
}
}
@media (min-width: 1280px) {
@@ -2992,9 +2911,4 @@ video {
margin-right: calc(1rem * var(--tw-space-x-reverse));
margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse)));
}
.\32xl\:px-0 {
padding-left: 0px;
padding-right: 0px;
}
}