/*
Theme Name: QueryLookup Landing
Theme URI: https://querylookup.com
Author: QueryLookup
Author URI: https://querylookup.com
Description: Premium one-page landing theme for QueryLookup — a dark, gradient-driven experience built to pitch blog monetization and SEO coaching in the age of AI Overviews. Includes a live interactive "Monetization Readiness Score" calculator, animated scroll reveals, and a direct booking CTA to Topmate.
Version: 1.0
Requires at least: 5.9
Requires PHP: 7.4
Text Domain: querylookup
*/

/* ==========================================================================
   0. TOKENS
   ========================================================================== */
:root{
  --ink:        #08070d;
  --ink-2:      #0f0e1a;
  --panel:      #14131f;
  --panel-2:    #1b1a29;
  --line:       rgba(255,255,255,0.08);
  --indigo:     #4f46e5;
  --violet:     #9333ea;
  --pink:       #ec4899;
  --amber:      #fbbf24;
  --text:       #f4f3f9;
  --text-dim:   #a9a6bd;
  --text-faint: #6f6c85;

  --grad-main:  linear-gradient(115deg, var(--indigo) 0%, var(--violet) 52%, var(--pink) 100%);
  --grad-soft:  linear-gradient(115deg, rgba(79,70,229,0.18) 0%, rgba(147,51,234,0.16) 52%, rgba(236,72,153,0.14) 100%);
  --grad-text:  linear-gradient(100deg, #c7c3ff 0%, #e7b6ff 45%, #ffd1e8 100%);

  --font-display: "Clash Display","Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-body:    "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-mono:    "IBM Plex Mono","JetBrains Mono",monospace;

  --container: 1180px;
  --radius: 20px;
  --radius-sm: 12px;
}

/* ==========================================================================
   1. RESET / BASE
   ========================================================================== */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
input,select{ font-family:inherit; }
:focus-visible{ outline:2px solid var(--amber); outline-offset:3px; border-radius:4px; }

.container{ max-width:var(--container); margin:0 auto; padding:0 28px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:18px;
}
.eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--grad-main); box-shadow:0 0 12px var(--pink); }

.grad-text{
  background:var(--grad-text);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.08; letter-spacing:-0.01em; }

.section{ position:relative; padding:130px 0; }
.section-head{ max-width:640px; margin-bottom:64px; }
.section-head p{ color:var(--text-dim); font-size:18px; margin-top:16px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity 0.9s cubic-bezier(.16,1,.3,1), transform 0.9s cubic-bezier(.16,1,.3,1); }
.reveal.is-visible{ opacity:1; transform:translateY(0); }
.reveal-stagger > *{ transition-delay:calc(var(--i,0) * 90ms); }

/* buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:16px 30px; border-radius:100px; font-weight:600; font-size:15px;
  white-space:nowrap; transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.btn-primary{
  background:var(--grad-main); color:#fff;
  box-shadow:0 8px 30px -8px rgba(147,51,234,0.65);
}
.btn-primary:hover{ transform:translateY(-2px) scale(1.015); box-shadow:0 14px 40px -8px rgba(236,72,153,0.6); }
.btn-ghost{
  border:1px solid var(--line); color:var(--text); background:rgba(255,255,255,0.03);
}
.btn-ghost:hover{ background:rgba(255,255,255,0.07); border-color:rgba(255,255,255,0.2); }
.btn-block{ width:100%; }

/* ==========================================================================
   2. NAV
   ========================================================================== */
.site-nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:18px 0;
  transition:background .4s ease, border-color .4s ease, padding .4s ease;
  border-bottom:1px solid transparent;
}
.site-nav.is-scrolled{
  background:rgba(8,7,13,0.72); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line); padding:13px 0;
}
.site-nav .container{ display:flex; align-items:center; justify-content:space-between; }
.brand{ font-family:var(--font-display); font-weight:600; font-size:19px; letter-spacing:-0.01em; display:flex; align-items:center; gap:9px; }
.brand-mark{ width:10px; height:10px; border-radius:3px; background:var(--grad-main); transform:rotate(45deg); }
.nav-links{ display:flex; gap:34px; font-size:14.5px; color:var(--text-dim); }
.nav-links a{ transition:color .25s; }
.nav-links a:hover{ color:var(--text); }
.nav-cta{ display:flex; align-items:center; gap:22px; }
.nav-cta .btn{ padding:11px 22px; font-size:14px; }
.nav-toggle{ display:none; }

@media (max-width:860px){
  .nav-links{ display:none; }
  .nav-cta .btn-ghost{ display:none; }
}

/* ==========================================================================
   3. HERO
   ========================================================================== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  padding:170px 0 110px;
  overflow:hidden;
}
.hero-mesh{
  position:absolute; inset:-20%;
  background:
    radial-gradient(38% 45% at 18% 22%, rgba(79,70,229,0.55), transparent 70%),
    radial-gradient(45% 50% at 85% 15%, rgba(236,72,153,0.4), transparent 70%),
    radial-gradient(50% 60% at 60% 90%, rgba(147,51,234,0.45), transparent 70%);
  filter:blur(60px);
  animation:meshDrift 22s ease-in-out infinite alternate;
  z-index:0;
}
@keyframes meshDrift{
  0%{ transform:translate3d(0,0,0) scale(1); }
  100%{ transform:translate3d(-2%,3%,0) scale(1.08); }
}
.hero-grain{
  position:absolute; inset:0; z-index:1; pointer-events:none; opacity:0.35;
  background-image:radial-gradient(rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size:3px 3px;
}
.hero .container{ position:relative; z-index:2; }
.hero-inner{ max-width:820px; }
.hero h1{
  font-size:clamp(38px,6.4vw,74px);
  margin-bottom:26px;
}
.hero-sub{
  font-size:clamp(17px,2vw,20px); color:var(--text-dim); max-width:600px; margin-bottom:42px;
}
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; margin-bottom:64px; }
.hero-actions .hint{ font-size:13px; color:var(--text-faint); font-family:var(--font-mono); }

.hero-strip{
  display:flex; gap:42px; flex-wrap:wrap;
  padding-top:34px; border-top:1px solid var(--line);
}
.hero-stat b{ display:block; font-family:var(--font-display); font-size:26px; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-stat span{ font-size:13px; color:var(--text-faint); }

/* ==========================================================================
   4. PAIN POINTS
   ========================================================================== */
.pain-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.pain-card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 30px; position:relative; overflow:hidden;
  transition:border-color .35s, transform .35s;
}
.pain-card:hover{ border-color:rgba(255,255,255,0.18); transform:translateY(-4px); }
.pain-card::before{
  content:""; position:absolute; inset:0; opacity:0; transition:opacity .4s;
  background:var(--grad-soft);
}
.pain-card:hover::before{ opacity:1; }
.pain-card > *{ position:relative; }
.pain-icon{
  width:44px; height:44px; border-radius:12px; margin-bottom:22px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.05); border:1px solid var(--line);
  font-size:19px;
}
.pain-card h3{ font-size:20px; margin-bottom:12px; }
.pain-card p{ color:var(--text-dim); font-size:15px; }

@media (max-width:900px){ .pain-grid{ grid-template-columns:1fr; } }

/* ==========================================================================
   5. METHOD / PROCESS
   ========================================================================== */
.method-list{ display:flex; flex-direction:column; }
.method-row{
  display:grid; grid-template-columns:90px 1fr 1fr; gap:36px;
  padding:38px 0; border-top:1px solid var(--line);
  align-items:start;
}
.method-list .method-row:last-child{ border-bottom:1px solid var(--line); }
.method-num{ font-family:var(--font-mono); font-size:14px; color:var(--text-faint); padding-top:6px; }
.method-row h3{ font-size:24px; margin-bottom:10px; }
.method-row p{ color:var(--text-dim); font-size:15.5px; }
.method-tag{
  display:inline-block; margin-top:16px; font-family:var(--font-mono); font-size:12px;
  color:#d9c8ff; background:rgba(147,51,234,0.14); border:1px solid rgba(147,51,234,0.35);
  padding:5px 12px; border-radius:100px;
}
@media (max-width:760px){
  .method-row{ grid-template-columns:1fr; gap:10px; }
}

/* ==========================================================================
   6. CALCULATOR
   ========================================================================== */
.calc-wrap{
  display:grid; grid-template-columns:1.05fr 0.95fr; gap:0;
  background:var(--panel); border:1px solid var(--line); border-radius:28px;
  overflow:hidden;
}
.calc-form{ padding:52px; }
.calc-field{ margin-bottom:26px; }
.calc-field label{
  display:flex; justify-content:space-between; font-size:13.5px; color:var(--text-dim);
  margin-bottom:12px; font-family:var(--font-mono);
}
.calc-field label span.val{ color:var(--text); font-weight:600; }
input[type="range"]{
  -webkit-appearance:none; width:100%; height:4px; border-radius:4px;
  background:var(--panel-2); outline:none;
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none; width:18px; height:18px; border-radius:50%;
  background:var(--grad-main); cursor:pointer; box-shadow:0 0 0 4px rgba(147,51,234,0.2);
}
input[type="range"]::-moz-range-thumb{
  width:18px; height:18px; border-radius:50%; background:var(--grad-main); border:none; cursor:pointer;
  box-shadow:0 0 0 4px rgba(147,51,234,0.2);
}
select.calc-select{
  width:100%; padding:13px 14px; border-radius:10px; background:var(--panel-2);
  border:1px solid var(--line); color:var(--text); font-size:14.5px;
}
.calc-chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  padding:9px 16px; border-radius:100px; border:1px solid var(--line); background:var(--panel-2);
  font-size:13.5px; color:var(--text-dim); transition:all .25s;
}
.chip input{ display:none; }
.chip.active{ color:#fff; border-color:transparent; background:var(--grad-main); }

.calc-result{
  position:relative; padding:52px;
  background:radial-gradient(120% 120% at 20% 0%, rgba(147,51,234,0.22), transparent 60%), var(--ink-2);
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  border-left:1px solid var(--line);
}
.gauge{ position:relative; width:200px; height:200px; margin-bottom:24px; }
.gauge svg{ width:100%; height:100%; transform:rotate(-90deg); }
.gauge-track{ fill:none; stroke:var(--panel-2); stroke-width:10; }
.gauge-fill{ fill:none; stroke:url(#gaugeGrad); stroke-width:10; stroke-linecap:round; transition:stroke-dashoffset .6s cubic-bezier(.16,1,.3,1); }
.gauge-number{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.gauge-number b{ font-family:var(--font-mono); font-size:42px; }
.gauge-number span{ font-size:11.5px; color:var(--text-faint); letter-spacing:0.08em; text-transform:uppercase; margin-top:2px; }
.calc-verdict{ font-size:15.5px; color:var(--text-dim); max-width:320px; margin-bottom:26px; min-height:48px; }
.calc-verdict b{ color:var(--text); }

@media (max-width:900px){
  .calc-wrap{ grid-template-columns:1fr; }
  .calc-result{ border-left:none; border-top:1px solid var(--line); }
  .calc-form, .calc-result{ padding:34px 26px; }
}

/* ==========================================================================
   7. TESTIMONIALS
   ========================================================================== */
.story-track{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.story-card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:32px; display:flex; flex-direction:column; gap:20px;
}
.story-arc{ display:flex; gap:8px; font-family:var(--font-mono); font-size:11px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.08em; }
.story-arc b{ color:#d9c8ff; }
.story-quote{ font-size:16px; line-height:1.65; color:var(--text); }
.story-quote em{ font-style:normal; color:transparent; background:var(--grad-text); -webkit-background-clip:text; background-clip:text; }
.story-foot{ display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:18px; border-top:1px solid var(--line); }
.story-avatar{
  width:42px; height:42px; border-radius:50%; background:var(--grad-main);
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:15px; color:#fff;
  flex-shrink:0;
}
.story-name{ font-size:14.5px; font-weight:600; }
.story-role{ font-size:12.5px; color:var(--text-faint); }
.story-metric{
  margin-left:auto; text-align:right; font-family:var(--font-mono); font-size:13px; color:var(--amber);
}

@media (max-width:960px){ .story-track{ grid-template-columns:1fr; } }

/* ==========================================================================
   8. FINAL CTA
   ========================================================================== */
.cta-panel{
  position:relative; border-radius:32px; overflow:hidden;
  padding:90px 40px; text-align:center;
  background:var(--grad-main);
}
.cta-panel::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(60% 80% at 50% 0%, rgba(255,255,255,0.25), transparent 60%);
}
.cta-panel > *{ position:relative; }
.cta-panel .eyebrow{ color:rgba(255,255,255,0.85); }
.cta-panel .eyebrow::before{ background:#fff; box-shadow:0 0 12px #fff; }
.cta-panel h2{ font-size:clamp(30px,4.6vw,52px); color:#fff; max-width:680px; margin:0 auto 18px; }
.cta-panel p{ color:rgba(255,255,255,0.85); font-size:17px; max-width:520px; margin:0 auto 38px; }
.cta-panel .btn-primary{ background:#0b0b14; box-shadow:0 10px 40px -10px rgba(0,0,0,0.6); }
.cta-panel .btn-primary:hover{ background:#000; }
.cta-note{ margin-top:20px; font-size:13px; color:rgba(255,255,255,0.7); font-family:var(--font-mono); }

/* ==========================================================================
   9. FOOTER
   ========================================================================== */
.site-footer{ padding:70px 0 40px; border-top:1px solid var(--line); }
.footer-top{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:40px; margin-bottom:50px; }
.footer-brand p{ color:var(--text-faint); font-size:14px; max-width:280px; margin-top:14px; }
.footer-cols{ display:flex; gap:70px; flex-wrap:wrap; }
.footer-col h4{ font-size:13px; color:var(--text-faint); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:16px; font-family:var(--font-mono); font-weight:500; }
.footer-col a, .footer-col li{ display:block; font-size:14.5px; color:var(--text-dim); margin-bottom:11px; transition:color .25s; }
.footer-col a:hover{ color:var(--text); }
.footer-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  padding-top:26px; border-top:1px solid var(--line);
  font-size:12.5px; color:var(--text-faint);
}

@media (max-width:640px){
  .section{ padding:80px 0; }
  .footer-top{ flex-direction:column; }
}
