/* ===== RESET & BASE ===== */
*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
scroll-behavior: smooth;
-webkit-font-smoothing: antialiased;
}
body {
font-family: "DM Sans", sans-serif;
transition:
background 0.3s,
color 0.3s;
}
/* ===== CSS VARIABLES ===== */
:root {
--bg: #0f071a;
--bg2: rgba(255, 255, 255, 0.04);
--bg3: rgba(255, 255, 255, 0.08);
--surface: #161028;
--surface2: #1d1535;
--border: rgba(255, 255, 255, 0.12);
--border2: rgba(255, 255, 255, 0.08);
--text: #f7f3ff;
--text2: rgba(247, 243, 255, 0.9);
--text3: rgba(247, 243, 255, 0.7);
--text4: rgba(247, 243, 255, 0.5);
--text-dark: #1f0a33;
--text-dark2: rgba(31, 10, 51, 0.8);
--text-dark3: rgba(31, 10, 51, 0.62);
--brand: #f54f7d;
--brand-light: #ff8a5c;
--brand-soft: rgba(245, 79, 125, 0.18);
--accent: #f76b6f;
--accent2: #ff9a7a;
--grad: linear-gradient(135deg, #ff8a5c 0%, #f54f7d 55%, #b92ad0 100%);
--grad2: linear-gradient(135deg, #17042e, #2b0a52);
--grad3: linear-gradient(135deg, #f76b6f, #f54f7d);
--chip-bg: #efe8f9;
--chip-border: #e2d7f3;
--card-shadow-app: 0 14px 30px rgba(33, 10, 55, 0.12);
--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
--shadow:
0 4px 6px -1px rgba(0, 0, 0, 0.06), 0 10px 15px -3px rgba(0, 0, 0, 0.07);
--shadow-lg:
0 10px 25px -5px rgba(0, 0, 0, 0.09), 0 20px 40px -10px rgba(0, 0, 0, 0.07);
--shadow-xl: 0 20px 60px rgba(0, 0, 0, 0.12);
}
.dark {
--bg: #1a0a2b;
--bg2: #1f0d34;
--bg3: #2a1044;
--surface: #211037;
--surface2: #2b1248;
--border: rgba(255, 170, 138, 0.18);
--border2: rgba(197, 8, 203, 0.16);
--text: #fdfbff;
--text2: rgba(255, 255, 255, 0.88);
--text3: rgba(255, 255, 255, 0.7);
--text4: rgba(255, 255, 255, 0.5);
--brand-soft: rgba(197, 8, 203, 0.16);
--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
--shadow:
0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 10px 15px -3px rgba(0, 0, 0, 0.3);
--shadow-lg:
0 10px 25px -5px rgba(0, 0, 0, 0.5), 0 20px 40px -10px rgba(0, 0, 0, 0.4);
--shadow-xl: 0 20px 60px rgba(0, 0, 0, 0.5);
}
body {
background: var(--bg);
color: var(--text);
}
/* ===== TYPOGRAPHY ===== */
h1,
h2,
h3,
h4,
h5 {
font-family: "Bricolage Grotesque", sans-serif;
line-height: 1.15;
}
/* ===== GRADIENT TEXT ===== */
.gt {
background: var(--grad);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.gt2 {
background: var(--grad2);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.gt3 {
background: var(--grad3);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
/* ===== BUTTONS ===== */
.btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
font-family: "DM Sans", sans-serif;
font-weight: 600;
cursor: pointer;
transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
border: none;
border-radius: 1rem;
white-space: nowrap;
}
.btn-primary {
background: var(--grad);
color: #fff;
box-shadow: 0 12px 26px rgba(245, 79, 125, 0.28);
}
.btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 16px 32px rgba(245, 79, 125, 0.35);
}
.btn-primary:active {
transform: translateY(0);
}
.btn-ghost {
background: transparent;
color: var(--brand);
border: 1.5px solid var(--border);
border-radius: 0.75rem;
}
.btn-ghost:hover {
border-color: var(--brand);
background: var(--brand-soft);
}
.btn-white {
background: #fff;
color: var(--brand);
box-shadow: var(--shadow);
border-radius: 0.75rem;
}
.btn-white:hover {
transform: translateY(-2px);
box-shadow: var(--shadow-lg);
}
/* ===== SURFACE / CARD ===== */
.card {
background: var(--surface);
border: 1px solid var(--border);
border-radius: 1.25rem;
box-shadow: var(--shadow);
color: var(--text);
}
.card-hover {
transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
.card-hover:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-xl);
border-color: var(--brand-light);
}
/* ===== GLASS ===== */
.glass {
background: rgba(255, 255, 255, 0.7);
backdrop-filter: blur(24px);
-webkit-backdrop-filter: blur(24px);
border: 1px solid rgba(255, 255, 255, 0.5);
}
.dark .glass {
background: rgba(17, 12, 34, 0.75);
border-color: rgba(255, 255, 255, 0.07);
}
/* ===== SECTION DIVIDER ===== */
.sec-label {
display: inline-flex;
align-items: center;
gap: 0.5rem;
background: var(--brand-soft);
color: var(--brand);
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.1em;
text-transform: uppercase;
padding: 0.35rem 1rem;
border-radius: 0.75rem;
border: 1px solid rgba(100, 12, 135, 0.2);
}
.dark .sec-label {
background: rgba(197, 8, 203, 0.12);
border-color: rgba(197, 8, 203, 0.25);
}
/* ===== NAV ===== */
#navbar {
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 1000;
transition: all 0.4s;
}
#navbar .nav-link {
color: var(--text3);
}
#navbar:not(.scrolled) .nav-link {
color: #f8f5ff;
}
#navbar:not(.scrolled) svg {
color: #f8f5ff;
}
#navbar.scrolled {
background: rgba(18, 8, 32, 0.92);
backdrop-filter: blur(18px);
-webkit-backdrop-filter: blur(18px);
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
}
/* ===== HERO ===== */
.hero-bg {
position: absolute;
inset: 0;
overflow: hidden;
pointer-events: none;
background: radial-gradient(
ellipse 80% 60% at 50% 0%,
rgba(92, 27, 141, 0.18) 0%,
transparent 70%
);
}
.dark .hero-bg {
background: radial-gradient(
ellipse 80% 60% at 50% 0%,
rgba(197, 8, 203, 0.2) 0%,
transparent 70%
);
}
.hero-shell {
background: linear-gradient(
180deg,
#120626 0%,
#1d0b33 44%,
var(--bg) 44%,
var(--bg) 100%
);
}
.dot-grid {
position: absolute;
inset: 0;
background-image: radial-gradient(
circle,
rgba(100, 12, 135, 0.14) 1px,
transparent 1px
);
background-size: 28px 28px;
mask-image: radial-gradient(
ellipse 80% 60% at 50% 0%,
black 0%,
transparent 80%
);
-webkit-mask-image: radial-gradient(
ellipse 80% 60% at 50% 0%,
black 0%,
transparent 80%
);
}
.dark .dot-grid {
background-image: radial-gradient(
circle,
rgba(197, 8, 203, 0.22) 1px,
transparent 1px
);
}
/* ===== PHONE MOCKUP ===== */
.phone {
width: 280px;
height: 570px;
border-radius: 44px;
background: var(--surface);
border: 8px solid rgba(0, 0, 0, 0.1);
box-shadow:
0 40px 80px rgba(0, 0, 0, 0.15),
0 0 0 1px rgba(0, 0, 0, 0.05),
inset 0 1px 0 rgba(255, 255, 255, 0.6);
position: relative;
overflow: hidden;
}
.dark .phone {
border-color: rgba(255, 255, 255, 0.1);
box-shadow:
0 40px 80px rgba(0, 0, 0, 0.5),
0 0 0 1px rgba(255, 255, 255, 0.07),
inset 0 1px 0 rgba(255, 255, 255, 0.1);
background: #1f0d34;
}
.phone-notch {
position: absolute;
top: 0;
left: 50%;
transform: translateX(-50%);
width: 100px;
height: 32px;
background: var(--bg);
z-index: 10;
border-radius: 0 0 20px 20px;
display: flex;
align-items: center;
justify-content: center;
}
.dark .phone-notch {
background: #1a0a2b;
}
/* ===== ANIMATIONS ===== */
@keyframes float {
0%,
100% {
transform: translateY(0) rotate(0deg);
}
50% {
transform: translateY(-18px) rotate(0.5deg);
}
}
@keyframes float2 {
0%,
100% {
transform: translateY(0);
}
50% {
transform: translateY(-12px);
}
}
@keyframes fade-up {
from {
opacity: 0;
transform: translateY(40px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes fade-in {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
@keyframes scale-in {
from {
opacity: 0;
transform: scale(0.9);
}
to {
opacity: 1;
transform: scale(1);
}
}
@keyframes slide-left {
from {
opacity: 0;
transform: translateX(40px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
@keyframes slide-right {
from {
opacity: 0;
transform: translateX(-40px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
@keyframes ping-slow {
0% {
transform: scale(1);
opacity: 0.5;
}
70% {
transform: scale(1.5);
opacity: 0;
}
100% {
transform: scale(1.5);
opacity: 0;
}
}
@keyframes spin-slow {
to {
transform: rotate(360deg);
}
}
@keyframes marquee {
from {
transform: translateX(0);
}
to {
transform: translateX(-50%);
}
}
@keyframes number-up {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes gradient-x {
0%,
100% {
background-position: 0% 50%;
}
50% {
background-position: 100% 50%;
}
}
@keyframes shimmer {
0% {
background-position: -200% 0;
}
100% {
background-position: 200% 0;
}
}
@keyframes blob {
0%,
100% {
border-radius: 60% 40% 30% 70%/60% 30% 70% 40%;
}
25% {
border-radius: 40% 60% 60% 40%/40% 60% 40% 60%;
}
50% {
border-radius: 30% 60% 70% 40%/50% 60% 30% 60%;
}
75% {
border-radius: 60% 40% 30% 70%/40% 50% 60% 50%;
}
}
@keyframes typing {
0% {
width: 0;
}
50% {
width: 100%;
}
90%,
100% {
width: 0;
}
}
@keyframes blink {
50% {
opacity: 0;
}
}
@keyframes drop-in {
from {
opacity: 0;
transform: translateY(-20px) scale(0.95);
}
to {
opacity: 1;
transform: translateY(0) scale(1);
}
}
.float {
animation: float 5s ease-in-out infinite;
}
.float2 {
animation: float2 4s ease-in-out infinite;
}
.float2d {
animation: float2 4s ease-in-out 1s infinite;
}
.spin-slow {
animation: spin-slow 30s linear infinite;
}
/* ===== REVEAL ===== */
.reveal,
.reveal-l,
.reveal-r,
.reveal-s {
opacity: 0;
transition:
opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal {
transform: translateY(36px);
}
.reveal-l {
transform: translateX(-36px);
}
.reveal-r {
transform: translateX(36px);
}
.reveal-s {
transform: scale(0.94);
}
.reveal.vis,
.reveal-l.vis,
.reveal-r.vis,
.reveal-s.vis {
opacity: 1;
transform: none;
}
.d1 {
transition-delay: 0.1s;
}
.d2 {
transition-delay: 0.18s;
}
.d3 {
transition-delay: 0.26s;
}
.d4 {
transition-delay: 0.34s;
}
.d5 {
transition-delay: 0.42s;
}
.d6 {
transition-delay: 0.5s;
}
/* ===== FEATURE ICON ===== */
.feat-icon {
width: 52px;
height: 52px;
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
transition: transform 0.3s;
}
.feat-card:hover .feat-icon {
transform: scale(1.1) rotate(-5deg);
}
/* ===== STEP ===== */
.step-num {
width: 44px;
height: 44px;
border-radius: 50%;
background: var(--grad);
color: #fff;
font-family: "Bricolage Grotesque", sans-serif;
font-weight: 700;
font-size: 1.1rem;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
box-shadow: 0 4px 15px rgba(100, 12, 135, 0.32);
}
/* ===== PRODUCT CARD ===== */
.prod-card {
cursor: pointer;
background: #ffffff;
color: var(--text-dark);
border: 1px solid #efe5fb;
border-radius: 1.15rem;
box-shadow: var(--card-shadow-app);
transition:
transform 0.3s ease,
box-shadow 0.3s ease,
border-color 0.3s ease;
}
.prod-card:hover {
transform: translateY(-6px);
box-shadow: var(--shadow-xl);
border-color: rgba(245, 79, 125, 0.35);
}
.prod-media {
position: relative;
height: 220px;
overflow: hidden;
border-bottom: 1px solid var(--border);
background: radial-gradient(
circle at 20% 20%,
rgba(245, 79, 125, 0.08),
rgba(43, 12, 90, 0.08)
);
}
.prod-media img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.prod-badge {
position: absolute;
top: 12px;
left: 12px;
background: rgba(255, 255, 255, 0.92);
color: var(--brand);
border-radius: 999px;
padding: 0.35rem 0.75rem;
font-size: 0.7rem;
font-weight: 700;
box-shadow: var(--shadow-sm);
}
.prod-fav {
position: absolute;
top: 12px;
right: 12px;
width: 36px;
height: 36px;
border-radius: 50%;
display: grid;
place-items: center;
background: rgba(255, 255, 255, 0.95);
color: var(--brand);
box-shadow: var(--shadow-sm);
}
.prod-body {
padding: 1rem 1.1rem 1.25rem;
color: var(--text-dark2);
}
.prod-meta {
font-size: 0.8rem;
font-weight: 600;
letter-spacing: 0.01em;
color: var(--text-dark3);
}
.prod-price {
font-weight: 800;
font-size: 1.05rem;
color: #d63d72;
}
.prod-rating {
display: inline-flex;
align-items: center;
gap: 0.25rem;
font-size: 0.78rem;
color: var(--text3);
}
.prod-card .add-btn {
opacity: 1;
transform: none;
width: 100%;
margin-top: 0.9rem;
border-radius: 0.9rem;
box-shadow: 0 14px 30px rgba(245, 79, 125, 0.25);
}
.prod-card:hover .add-btn {
transform: none;
}
.prod-img {
transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.prod-card:hover .prod-img {
transform: scale(1.04);
}
/* ===== MARKETPLACE PRODUCT CARDS ===== */
.prod-card.marketplace {
background: var(--surface);
color: var(--text);
border: 1px solid var(--border);
border-radius: 0.75rem;
overflow: hidden;
}
.prod-card.marketplace:hover {
border-color: rgba(245, 79, 125, 0.3);
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}
.prod-media.marketplace {
position: relative;
height: 160px;
border-bottom: none;
background: rgba(0, 0, 0, 0.2);
}
.prod-discount-badge {
position: absolute;
top: 6px;
right: 6px;
background: #e74c3c;
color: #fff;
padding: 0.25rem 0.5rem;
border-radius: 0.4rem;
font-size: 0.7rem;
font-weight: 800;
z-index: 2;
}
.prod-badge-marketplace {
position: absolute;
top: 6px;
left: 6px;
padding: 0.25rem 0.6rem;
border-radius: 0.35rem;
font-size: 0.65rem;
font-weight: 800;
z-index: 2;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.prod-badge-marketplace.fast {
background: #3498db;
color: #fff;
}
.prod-badge-marketplace.hot {
background: #e74c3c;
color: #fff;
}
.prod-badge-marketplace.deal {
background: #f39c12;
color: #fff;
}
.prod-badge-marketplace.trending {
background: #9b59b6;
color: #fff;
}
.prod-badge-marketplace.premium {
background: #f1c40f;
color: #000;
}
.prod-fav.marketplace {
width: 32px;
height: 32px;
font-size: 0.9rem;
}
.prod-body.marketplace {
padding: 0.8rem;
}
.prod-seller {
font-size: 0.75rem !important;
color: var(--text4) !important;
margin-bottom: 0.25rem !important;
}
.prod-title.marketplace {
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
font-size: 0.9rem !important;
line-height: 1.2 !important;
font-weight: 600 !important;
margin: 0 0 0.4rem 0 !important;
}
.prod-rating-section {
display: flex;
align-items: center;
gap: 0.3rem;
margin: 0.3rem 0;
font-size: 0.8rem;
}
.prod-rating-section span {
display: inline-flex;
align-items: center;
gap: 0.2rem;
}
.prod-price-section.marketplace {
margin: 0.5rem 0;
padding: 0.4rem 0;
}
.prod-price-new {
font-weight: 800;
font-size: 1rem;
color: #f54f7d;
}
.prod-price-old {
font-size: 0.8rem;
color: var(--text4);
text-decoration: line-through;
margin-left: 0.4rem;
}
.prod-card.marketplace .add-btn {
opacity: 1;
transform: none;
width: 100%;
margin-top: 0.6rem;
padding: 0.6rem 0.8rem !important;
font-size: 0.8rem;
border-radius: 0.6rem;
box-shadow: none;
}
.prod-card.marketplace:hover .add-btn {
transform: none;
}
/* ===== INPUTS ===== */
.inp {
font-family: inherit;
font-size: 1rem;
outline: none;
}
/* ===== SELECT ===== */
select.inp {
cursor: pointer;
appearance: none;
padding-right: 2rem;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23fdfbff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 0.75rem center;
background-size: 12px;
}
/* ===== CATEGORY WRAPPER ===== */
background: linear-gradient(
180deg,
#160428 0%,
#1d0b33 46%,
var(--bg) 46%,
var(--bg) 100%
);
}
.cat-shell {
position: relative;
}
.cat-head {
background: linear-gradient(135deg, #1f0a36, #2b0a52);
color: #fff;
padding: 2.25rem;
border-radius: 1.5rem;
border: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: var(--shadow-xl);
}
.cat-head h2 {
color: #fff;
}
.cat-eyebrow {
font-size: 0.8rem;
letter-spacing: 0.12em;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.72);
font-weight: 700;
}
.cat-chips {
margin-top: 1.2rem;
display: flex;
flex-wrap: wrap;
gap: 0.6rem;
}
.cat-filter {
display: inline-flex;
align-items: center;
gap: 0.45rem;
padding: 0.55rem 0.95rem;
border-radius: 999px;
font-weight: 700;
font-size: 0.9rem;
background: #ffffff;
color: var(--text3);
border: 1px solid #ece4f6;
box-shadow: 0 8px 18px rgba(33, 10, 55, 0.08);
transition: all 0.2s ease;
cursor: pointer;
}
.cat-filter i {
font-size: 0.95rem;
}
.cat-filter.active {
background: linear-gradient(135deg, #f76b6f, #f54f7d);
color: #fff;
border: none;
box-shadow: 0 14px 30px rgba(245, 79, 125, 0.35);
}
.dark .cat-filter {
background: rgba(255, 255, 255, 0.08);
color: rgba(255, 255, 255, 0.82);
border-color: rgba(255, 255, 255, 0.08);
box-shadow: none;
}
.dark .cat-filter.active {
background: linear-gradient(135deg, #f76b6f, #f54f7d);
color: #fff;
border: none;
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}
.cat-grid {
position: relative;
margin-top: -80px;
background: #fff;
border-radius: 1.5rem;
border: 1px solid #e9e1f5;
box-shadow: var(--shadow-xl);
padding: 1.5rem;
}
.dark .cat-grid {
background: #1f0d34;
border-color: rgba(255, 255, 255, 0.08);
}
@media (max-width: 768px) {
.cat-grid {
margin-top: -60px;
}
.cat-head {
padding: 1.8rem;
}
}
/* ===== TESTIMONIAL ===== */
.quote-mark {
font-size: 5rem;
line-height: 1;
color: var(--brand);
opacity: 0.12;
font-family: "Bricolage Grotesque", sans-serif;
position: absolute;
top: -1rem;
left: 1.5rem;
user-select: none;
}
/* ===== FAQ ===== */
.faq-item .faq-answer {
max-height: 0;
overflow: hidden;
transition:
max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1),
opacity 0.3s;
}
.faq-item.open .faq-answer {
max-height: 300px;
}
.faq-item .faq-icon {
transition: transform 0.3s;
}
.faq-item.open .faq-icon {
transform: rotate(45deg);
}
/* ===== MODAL ===== */
.modal-backdrop {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.5);
backdrop-filter: blur(6px);
z-index: 9000;
display: none;
align-items: center;
justify-content: center;
padding: 1rem;
}
.modal-backdrop.open {
display: flex;
animation: fade-in 0.2s both;
}
.modal-panel {
background: var(--surface);
border: 1px solid var(--border);
border-radius: 1.5rem;
width: 100%;
max-width: 740px;
max-height: 88vh;
display: flex;
flex-direction: column;
overflow: hidden;
box-shadow: var(--shadow-xl);
animation: scale-in 0.25s both;
}
.modal-head {
padding: 1.5rem 2rem;
border-bottom: 1px solid var(--border);
display: flex;
align-items: center;
justify-content: space-between;
flex-shrink: 0;
}
.modal-body {
padding: 2rem;
overflow-y: auto;
flex: 1;
}
.modal-body::-webkit-scrollbar {
width: 4px;
}
.modal-body::-webkit-scrollbar-thumb {
background: var(--brand-light);
border-radius: 2px;
}
.modal-body h3 {
font-family: "Bricolage Grotesque", sans-serif;
font-weight: 600;
font-size: 1.05rem;
color: var(--brand);
margin: 1.5rem 0 0.5rem;
}
.modal-body p {
color: var(--text3);
line-height: 1.75;
margin-bottom: 0.75rem;
font-size: 0.9rem;
}
.modal-body ul {
list-style: none;
padding: 0;
margin-bottom: 0.75rem;
}
.modal-body ul li {
color: var(--text3);
padding: 0.3rem 0 0.3rem 1.3rem;
position: relative;
font-size: 0.9rem;
line-height: 1.65;
}
.modal-body ul li::before {
content: "→";
position: absolute;
left: 0;
color: var(--brand);
font-size: 0.85rem;
}
/* ===== SCROLLBAR ===== */
::-webkit-scrollbar {
width: 5px;
}
::-webkit-scrollbar-track {
background: transparent;
}
::-webkit-scrollbar-thumb {
background: rgba(197, 8, 203, 0.25);
border-radius: 3px;
}
/* ===== COOKIE BANNER ===== */
#cookie {
position: fixed;
bottom: 1.5rem;
left: 50%;
transform: translateX(-50%);
z-index: 5000;
animation: drop-in 0.5s 2.5s both;
width: calc(100% - 3rem);
max-width: 480px;
}
/* ===== TOAST ===== */
#toast {
position: fixed;
bottom: 2rem;
right: 2rem;
z-index: 4000;
transform: translateY(80px);
opacity: 0;
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
#toast.show {
transform: translateY(0);
opacity: 1;
}
/* ===== MARQUEE ===== */
.marquee {
overflow: hidden;
}
.marquee-inner {
display: flex;
width: max-content;
animation: marquee 28s linear infinite;
}
.marquee:hover .marquee-inner {
animation-play-state: paused;
}
/* ===== GRADIENT ANIMATED BG ===== */
.animated-bg {
background-size: 300% 300%;
animation: gradient-x 10s ease infinite;
}
/* ===== SECTION DIVIDER WAVE ===== */
.wave-top {
position: absolute;
top: -1px;
left: 0;
right: 0;
}
.wave-bottom {
position: absolute;
bottom: -1px;
left: 0;
right: 0;
}
/* ===== STAT CARD ===== */
.stat-card {
background: var(--surface);
border: 1px solid var(--border);
border-radius: 1.25rem;
padding: 1.75rem;
box-shadow: var(--shadow-sm);
}
/* ===== INPUT ===== */
.inp {
width: 100%;
padding: 0.75rem 1rem;
background: var(--bg2);
border: 1.5px solid var(--border);
border-radius: 0.75rem;
color: var(--text);
font-family: "DM Sans", sans-serif;
font-size: 0.9rem;
outline: none;
transition:
border-color 0.2s,
box-shadow 0.2s;
}
.inp:focus {
border-color: var(--brand);
box-shadow: 0 0 0 3px rgba(197, 8, 203, 0.14);
}
.inp::placeholder {
color: var(--text4);
}
/* ===== PRICING BADGE ===== */
.badge {
display: inline-flex;
align-items: center;
gap: 0.3rem;
padding: 0.25rem 0.75rem;
border-radius: 999px;
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
}
/* ===== PROGRESS BAR ===== */
.prog-bar {
height: 6px;
border-radius: 3px;
background: var(--border);
overflow: hidden;
}
.prog-fill {
height: 100%;
border-radius: 3px;
background: var(--grad);
transition: width 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}
/* ===== COMPARISON TABLE ===== */
.check {
color: var(--accent2);
}
.cross {
color: var(--accent);
}
/* ===== FULL RESPONSIVE FIXES ===== */
/* Extra large screens (1280px+) */
@media (min-width: 1280px) {
  h1.hero-h1 { font-size: 4.5rem !important; }
  h2 { font-size: 3.5rem !important; }
}

/* Large screens (1024px - 1279px) */
@media (max-width: 1279px) {
  h1.hero-h1 { font-size: 3.5rem !important; }
  h2 { font-size: 2.75rem !important; }
  .phone { width: 260px; height: 530px; }
  #download .relative { border-radius: 24px; }
}

/* Tablet screens (768px - 1023px) */
@media (max-width: 1023px) {
  h1.hero-h1 { font-size: 3rem !important; line-height: 1.15; }
  h2 { font-size: 2.25rem !important; }
  h3 { font-size: 1.25rem !important; }
  
  section { padding: 4rem 1rem !important; }
  #hero { min-height: auto; padding-top: 8rem; padding-bottom: 4rem; }
  #hero .grid { gap: 3rem; }
  
  .phone { width: 220px; height: 450px; }
  
  .grid.md\:grid-cols-2 { grid-template-columns: 1fr; }
  .grid.lg\:grid-cols-3 { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .grid.lg\:grid-cols-4 { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  
  #how .absolute.top-6 { display: none !important; }
  
  #download .grid { gap: 3rem; padding: 3rem !important; }
  #download .flex.flex-col.lg\:flex-row { gap: 2rem; }
  
  .feat-card { padding: 1.5rem !important; }
  .card { padding: 1.5rem !important; }
}

/* Mobile large (640px - 767px) */
@media (max-width: 767px) {
  h1.hero-h1 { font-size: 2.5rem !important; }
  h2 { font-size: 2rem !important; }
  p { font-size: 0.95rem !important; }
  
  section { padding: 3rem 1rem !important; }
  #hero { padding-top: 7rem; padding-bottom: 3rem; }
  
  #navbar { padding: 0.75rem 1rem !important; }
  #navbar img { height: 2rem !important; }
  #navbar .btn { padding: 0.5rem 1rem !important; font-size: 0.8rem; }
  
  .phone { width: 180px; height: 370px; }
  .phone-notch { width: 70px; height: 24px; }
  
  .grid.lg\:grid-cols-2,
  .grid.lg\:grid-cols-3,
  .grid.lg\:grid-cols-4,
  .grid.md\:grid-cols-2,
  .grid.md\:grid-cols-4 { grid-template-columns: 1fr !important; gap: 1rem; }
  
  .flex.flex-wrap { gap: 0.75rem; }
  .btn { padding: 0.625rem 1.25rem !important; font-size: 0.875rem !important; }
  
  footer .grid { grid-template-columns: 1fr !important; gap: 2rem; }
  footer .flex.flex-col.md\:flex-row { flex-direction: column; text-align: center; gap: 1rem; }
  
  #download .grid { grid-template-columns: 1fr !important; padding: 2rem !important; }
  #download .flex.flex-col.lg\:flex-row { flex-direction: column; align-items: center; }
  #download .relative .w-\\[280px\\] { width: 200px; height: 410px; }
  #download .bg-white { width: 180px; height: 180px; padding: 1rem; }
  
  .marquee-inner { animation-duration: 40s; }
  .marquee .gap-14 { gap: 2.5rem; }
  
  .feat-icon { width: 44px; height: 44px; font-size: 1.5rem; }
  .step-num { width: 36px; height: 36px; font-size: 1rem; }
  
  #newsletterForm { flex-direction: column; }
  #newsletterForm .btn { width: 100%; }
}

/* Mobile medium (480px - 639px) */
@media (max-width: 639px) {
  h1.hero-h1 { font-size: 2.1rem !important; }
  h2 { font-size: 1.75rem !important; }
  
  .max-w-7xl { padding-left: 1rem !important; padding-right: 1rem !important; }
  
  .phone { width: 160px; height: 330px; }
  
  #hero .flex.flex-wrap { justify-content: center; }
  #hero .flex.items-center.gap-5 { justify-content: center; }
  
  .modal-head { padding: 1rem 1.25rem; }
  .modal-body { padding: 1.25rem; }
  .modal-panel { border-radius: 1rem; }
  
  .sec-label { font-size: 0.65rem; padding: 0.25rem 0.75rem; }
}

/* Mobile small (360px - 479px) */
@media (max-width: 479px) {
  h1.hero-h1 { font-size: 1.8rem !important; }
  h2 { font-size: 1.5rem !important; }
  
  section { padding: 2.5rem 0.75rem !important; }
  #hero { padding-top: 6rem; padding-bottom: 2.5rem; }
  
  .phone { width: 140px; height: 290px; }
  
  .btn { padding: 0.5rem 1rem !important; font-size: 0.8rem !important; }
  .btn img { height: 1rem !important; }
  
  .feat-card { padding: 1.25rem !important; }
  .card { padding: 1.25rem !important; }
  
  .trust-bar .text-3xl { font-size: 1.75rem !important; }
  
  .marquee .gap-14 { gap: 2rem; }
  .marquee .text-sm { font-size: 0.8rem; }
  
  #download .relative .w-\\[280px\\] { width: 170px; height: 350px; }
  #download .bg-white { width: 150px; height: 150px; }
  
  footer { padding: 3rem 1rem 2rem 1rem !important; }
}

/* Mobile extra small (< 360px) */
@media (max-width: 359px) {
  h1.hero-h1 { font-size: 1.6rem !important; }
  h2 { font-size: 1.3rem !important; }
  
  .phone { width: 120px; height: 250px; }
  
  .max-w-7xl { padding-left: 0.5rem !important; padding-right: 0.5rem !important; }
  
  .btn { padding: 0.5rem 0.75rem !important; font-size: 0.75rem !important; }
  
  .marquee-inner { animation-duration: 50s; }
}

/* Safe area for notch devices */
@supports (padding-top: env(safe-area-inset-top)) {
  #navbar {
    padding-top: calc(1rem + env(safe-area-inset-top)) !important;
  }
  body {
    padding-bottom: env(safe-area-inset-bottom);
  }
}

/* Prevent overflow on mobile */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

* {
  max-width: 100%;
  box-sizing: border-box;
}
/* ===== NOISE TEXTURE ===== */
.noise::before {
content: "";
position: absolute;
inset: 0;
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");
pointer-events: none;
z-index: 0;
border-radius: inherit;
}
/* Highlight box */
.highlight-box {
background: linear-gradient(
135deg,
rgba(100, 12, 135, 0.06),
rgba(247, 87, 130, 0.05)
);
border: 1px solid rgba(100, 12, 135, 0.12);
border-radius: 1rem;
padding: 1.25rem;
}
.dark .highlight-box {
background: linear-gradient(
135deg,
rgba(197, 8, 203, 0.12),
rgba(247, 87, 130, 0.08)
);
border-color: rgba(197, 8, 203, 0.2);
}
