/* =============================================
   Lovixo – Complete Stylesheet (No Tailwind)
   ============================================= */

/* === BASE & RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }

/* === CSS VARIABLES === */
:root {
  --pink:    #ff4d6d;
  --purple:  #7b2cbf;
  --dark:    #0f0c29;
  --dark2:   #302b63;
  --dark3:   #24243e;
  --g300: #d1d5db;
  --g400: #9ca3af;
  --g500: #6b7280;
  --g800: #1f2937;
  --white: #ffffff;
  --gradient: linear-gradient(135deg, var(--pink), var(--purple));
}

/* === BODY === */
body {
  font-family: 'Inter', 'Segoe UI', sans-serif;
  background: linear-gradient(135deg, #0f0c29 0%, #302b63 50%, #24243e 100%);
  background-attachment: fixed;
  color: #fff;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 { font-family: 'Poppins','Segoe UI',sans-serif; }

/* === CANVAS HEARTS === */
#hearts-canvas {
  position: fixed; top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none; z-index: 0;
}

/* === CONTAINER === */
.container { max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }
.container-sm { max-width: 900px; margin: 0 auto; padding: 0 1.5rem; }

/* === FLEX UTILITIES === */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-start { justify-content: flex-start; }
.gap-2 { gap: .5rem; }
.gap-3 { gap: .75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }
.gap-8 { gap: 2rem; }
.gap-12 { gap: 3rem; }
.flex-1 { flex: 1; }
.shrink-0 { flex-shrink: 0; }

/* === GRID UTILITIES === */
.grid { display: grid; }
.grid-2 { grid-template-columns: 1fr 1fr; gap: 2rem; }
.grid-3 { grid-template-columns: repeat(3,1fr); gap: 2rem; }
.grid-4 { grid-template-columns: repeat(4,1fr); gap: 1.5rem; }

/* === SPACING === */
.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mt-24{margin-top:6rem}
.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-20{margin-bottom:5rem}
.mx-auto{margin-left:auto;margin-right:auto}
.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.pt-12{padding-top:3rem}.pt-24{padding-top:6rem}.pt-32{padding-top:8rem}
.pb-8{padding-bottom:2rem}.pb-16{padding-bottom:4rem}.pb-20{padding-bottom:5rem}
.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-10{padding:2.5rem}.p-12{padding:3rem}
.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}

/* === DISPLAY === */
.block{display:block}.inline-block{display:inline-block}.hidden{display:none}
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}
.inset-0{top:0;left:0;right:0;bottom:0}
.top-0{top:0}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}
.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}
.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}

/* === TYPOGRAPHY === */
.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}
.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}
.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.text-5xl{font-size:3rem}.text-6xl{font-size:3.75rem}.text-7xl{font-size:4.5rem}
.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}
.leading-tight{line-height:1.25}.leading-relaxed{line-height:1.625}.leading-none{line-height:1}
.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}
.uppercase{text-transform:uppercase}
.text-center{text-align:center}.text-left{text-align:left}
.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-5xl{max-width:64rem}

/* === COLORS === */
.text-white{color:#fff}.text-g300{color:var(--g300)}.text-g400{color:var(--g400)}.text-g500{color:var(--g500)}
.text-pink{color:var(--pink)}.text-purple{color:var(--purple)}
.text-red{color:#f87171}.text-blue{color:#60a5fa}.text-green{color:#4ade80}
.bg-black-30{background:rgba(0,0,0,.3)}

/* === GRADIENT TEXT === */
.text-gradient {
  background: linear-gradient(to right, var(--pink), var(--purple));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* === BORDER === */
.border { border: 1px solid rgba(255,255,255,.1); }
.border-white10 { border: 1px solid rgba(255,255,255,.1); }
.border-pink { border: 1px solid var(--pink); }
.border-top-pink { border-top: 4px solid var(--pink); }
.border-top-purple { border-top: 4px solid var(--purple); }
.border-b { border-bottom: 1px solid rgba(255,255,255,.1); }
.border-t { border-top: 1px solid rgba(255,255,255,.1); }
.rounded { border-radius: .5rem; }
.rounded-lg { border-radius: .75rem; }
.rounded-xl { border-radius: 1rem; }
.rounded-2xl { border-radius: 1.5rem; }
.rounded-3xl { border-radius: 1.75rem; }
.rounded-full { border-radius: 9999px; }

/* === SHADOW === */
.shadow-lg { box-shadow: 0 10px 40px rgba(0,0,0,.4); }
.shadow-pink { box-shadow: 0 0 30px rgba(255,77,109,.4); }
.shadow-purple { box-shadow: 0 0 30px rgba(123,44,191,.4); }

/* === GLASSMORPHISM === */
.glass {
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 8px 32px rgba(0,0,0,.3);
}
.glass-card {
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 1.5rem;
  box-shadow: 0 4px 24px rgba(0,0,0,.25);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.glass-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(255,77,109,.2);
  border-color: rgba(255,77,109,.3);
}

/* === BUTTONS === */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5rem; padding: .9rem 2rem; border-radius: 9999px;
  font-weight: 700; font-size: 1rem; cursor: pointer;
  border: none; transition: all .3s ease; position: relative; overflow: hidden;
}
.btn-primary {
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: #fff;
  box-shadow: 0 4px 20px rgba(255,77,109,.4);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(255,77,109,.6); }
.btn-outline {
  background: rgba(255,255,255,.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,.2);
}
.btn-outline:hover { background: rgba(255,255,255,.15); transform: translateY(-2px); }
.btn-white {
  background: #fff; color: #111;
  box-shadow: 0 4px 20px rgba(0,0,0,.2);
}
.btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.3); }

/* === ICON BOX === */
.icon-box {
  width: 3.5rem; height: 3.5rem; border-radius: 1rem;
  display: flex; align-items: center; justify-center: center;
  justify-content: center;
  flex-shrink: 0;
}
.icon-box svg { width: 1.75rem; height: 1.75rem; color: #fff; stroke: #fff; fill: none; }
.icon-pink { background: linear-gradient(135deg,#ff4d6d,#f43f5e); box-shadow: 0 4px 15px rgba(255,77,109,.35); }
.icon-purple { background: linear-gradient(135deg,#7b2cbf,#6d28d9); box-shadow: 0 4px 15px rgba(123,44,191,.35); }
.icon-blue { background: linear-gradient(135deg,#3b82f6,#06b6d4); box-shadow: 0 4px 15px rgba(59,130,246,.35); }
.icon-green { background: linear-gradient(135deg,#10b981,#06b6d4); box-shadow: 0 4px 15px rgba(16,185,129,.35); }

/* === GRADIENT BADGE === */
.badge {
  display: inline-block; padding: .4rem 1.2rem;
  background: rgba(255,77,109,.15); border: 1px solid rgba(255,77,109,.3);
  border-radius: 9999px; font-size: .8rem; font-weight: 600;
  color: var(--pink); text-transform: uppercase; letter-spacing: .05em;
}

/* === SECTION === */
.section { padding: 5rem 0; position: relative; z-index: 1; }
.section-dark { background: rgba(0,0,0,.2); border-top: 1px solid rgba(255,255,255,.05); border-bottom: 1px solid rgba(255,255,255,.05); }

/* === SCROLL BAR === */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: #0f0c29; }
::-webkit-scrollbar-thumb { background: var(--purple); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--pink); }

/* === MISC === */
.opacity-0{opacity:0}.opacity-50{opacity:.5}
.object-cover{object-fit:cover}
.transition { transition: all .3s ease; }
.cursor-pointer { cursor: pointer; }

/* =============================================
   3D NAVBAR
   ============================================= */
.qm-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  perspective: 2000px;
}
.qm-nav-inner {
  background: rgba(10, 8, 35, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,77,109,.2);
  box-shadow:
    0 1px 0 rgba(255,255,255,.06) inset,
    0 6px 30px rgba(0,0,0,.5),
    0 1px 60px rgba(123,44,191,.15);
  transform: translateZ(0);
  padding: 0 2rem;
}
.qm-nav-container {
  max-width: 1280px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 85px;
}
/* Logo */
.qm-logo {
  display: flex; align-items: center;
  text-decoration: none; flex-shrink: 0;
  transition: transform .3s ease;
}
.qm-logo:hover { transform: scale(1.05); }


/* Desktop Links */
.qm-links {
  display: flex; align-items: center; gap: .25rem;
  list-style: none; margin: 0; padding: 0;
}
.qm-links li { position: relative; }
.qm-links > li > a {
  display: flex; align-items: center; gap: .3rem;
  padding: .5rem 1rem; border-radius: .75rem;
  font-size: .9rem; font-weight: 500; color: rgba(255,255,255,.7);
  text-decoration: none;
  transition: all .2s ease;
  position: relative;
}
.qm-links > li > a::after {
  content: '';
  position: absolute; bottom: 4px; left: 50%; right: 50%;
  height: 2px; background: var(--pink);
  border-radius: 2px;
  transition: left .25s ease, right .25s ease;
}
.qm-links > li > a:hover { color: #fff; background: rgba(255,255,255,.06); }
.qm-links > li > a:hover::after { left: 12px; right: 12px; }

/* Dropdown */
.qm-dropdown { position: relative; }
.qm-dropdown-menu {
  position: absolute; top: calc(100% + 8px); left: 50%;
  transform: translateX(-50%) translateY(-8px);
  background: rgba(15,12,41,.95);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,77,109,.2);
  border-radius: 1rem;
  padding: .5rem;
  min-width: 210px;
  box-shadow: 0 20px 40px rgba(0,0,0,.5);
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
  z-index: 100;
}
.qm-dropdown:hover .qm-dropdown-menu {
  opacity: 1; pointer-events: all;
  transform: translateX(-50%) translateY(0);
}
.qm-dropdown-menu a {
  display: block; padding: .6rem 1rem;
  font-size: .875rem; color: rgba(255,255,255,.7);
  border-radius: .6rem;
  transition: all .2s ease;
  text-decoration: none;
}
.qm-dropdown-menu a:hover { color: #fff; background: rgba(255,77,109,.15); }

/* CTA Button */
.qm-nav-cta {
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: #fff; font-weight: 700; font-size: .9rem;
  padding: .6rem 1.5rem; border-radius: 9999px;
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(255,77,109,.35);
  transition: all .3s ease;
  white-space: nowrap;
}
.qm-nav-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(255,77,109,.55); }

/* Mobile Toggle */
.qm-mobile-btn {
  display: none; background: none; border: none; cursor: pointer;
  color: #fff; padding: .4rem;
}
.qm-mobile-btn svg { width: 26px; height: 26px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; }

/* Mobile Menu */
.qm-mobile-menu {
  display: none;
  background: rgba(10,8,35,.97);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(255,77,109,.15);
  padding: 1rem 1.5rem 1.5rem;
}
.qm-mobile-menu.open { display: block; }
.qm-mobile-menu a {
  display: block; padding: .75rem 1rem;
  color: rgba(255,255,255,.8); font-weight: 500;
  border-radius: .75rem;
  text-decoration: none;
  transition: all .2s ease;
}
.qm-mobile-menu a:hover { color: #fff; background: rgba(255,255,255,.07); }
.qm-mobile-menu .divider { height: 1px; background: rgba(255,255,255,.08); margin: .5rem 0; }
.qm-mobile-cta {
  display: block; margin-top: 1rem; text-align: center;
  background: linear-gradient(135deg, var(--pink), var(--purple));
  color: #fff; font-weight: 700; padding: .85rem 1.5rem;
  border-radius: 1rem; text-decoration: none;
  box-shadow: 0 4px 20px rgba(255,77,109,.3);
}

@media (max-width: 900px) {
  .qm-links, .qm-nav-cta { display: none !important; }
  .qm-mobile-btn { display: flex; }
}

/* Responsive grid */
@media (max-width: 900px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .text-7xl { font-size: 2.8rem; }
  .text-6xl { font-size: 2.4rem; }
  .text-5xl { font-size: 2rem; }
}
@media (max-width: 600px) {
  .text-4xl { font-size: 1.8rem; }
  .text-3xl { font-size: 1.5rem; }
  .section { padding: 3rem 0; }
}

/* === HERO MOCKUP === */
.phone-mockup {
  width: 260px; height: 520px;
  background: #111;
  border-radius: 40px;
  border: 7px solid #2a2a3e;
  box-shadow: 0 30px 60px rgba(0,0,0,.6), 0 0 40px rgba(255,77,109,.2);
  overflow: hidden;
  transform: rotate(-4deg);
  transition: transform .5s ease;
  flex-shrink: 0;
}
.phone-mockup:hover { transform: rotate(0deg); }

/* === GLOW BLOB === */
.blob-pink {
  position: absolute;
  width: 400px; height: 400px;
  background: rgba(255,77,109,.2);
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}
.blob-purple {
  position: absolute;
  width: 350px; height: 350px;
  background: rgba(123,44,191,.2);
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}

/* pulse animation */
@keyframes pulse { 0%,100%{opacity:.7;transform:scale(1)} 50%{opacity:1;transform:scale(1.05)} }
.animate-pulse { animation: pulse 3s ease-in-out infinite; }

/* === FOOTER === */
.qm-footer { margin-top: auto; position: relative; z-index: 1; border-top: 1px solid rgba(255,255,255,.08); background: rgba(0,0,0,.2); padding: 4rem 0 2rem; }
.qm-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 3rem; margin-bottom: 3rem; }
.qm-footer-copy { border-top: 1px solid rgba(255,255,255,.08); padding-top: 2rem; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.qm-social { display: flex; gap: .75rem; }
.qm-social a {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.07); display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6); transition: all .3s ease;
}
.qm-social a:hover { background: var(--pink); color: #fff; transform: translateY(-2px); }
.qm-social a svg { width: 16px; height: 16px; fill: currentColor; }
.qm-footer-links h4 { color: #fff; font-family: 'Poppins',sans-serif; font-weight: 600; margin-bottom: 1rem; font-size: .95rem; }
.qm-footer-links ul { display: flex; flex-direction: column; gap: .6rem; }
.qm-footer-links ul a { color: var(--g400); font-size: .875rem; transition: color .2s; }
.qm-footer-links ul a:hover { color: var(--pink); }

/* Store badges */
.store-badge {
  display: flex; align-items: center; gap: .75rem;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  border-radius: .75rem; padding: .6rem .9rem;
  transition: all .2s ease;
}
.store-badge:hover { background: rgba(255,255,255,.12); border-color: rgba(255,77,109,.3); }
.store-badge svg { width: 24px; height: 24px; fill: #fff; flex-shrink: 0; }
.store-badge-text span:first-child { display: block; font-size: .65rem; color: var(--g400); text-transform: uppercase; letter-spacing: .04em; }
.store-badge-text span:last-child { display: block; font-size: .9rem; font-weight: 600; color: #fff; }

@media (max-width: 900px) {
  .qm-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .qm-footer-grid { grid-template-columns: 1fr; }
  .qm-footer-copy { flex-direction: column; text-align: center; }
}
