/*
Theme Name: Visual Profit Media
Theme URI: https://visualprofitmedia.com
Author: Visual Profit Media
Author URI: https://visualprofitmedia.com
Description: Custom WordPress theme for Visual Profit Media — animated explainer videos for financial and health businesses.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: Private
Text Domain: vpm
*/

/* ============ TOKENS ============ */
:root{
  --ink:        #0f0e0c;
  --ink-2:      #1b1712;
  --ink-3:      #262019;
  --cream:      #f5f0e8;
  --cream-dim:  #c9c1b4;
  --gold:       #d4963a;
  --rust:       #c24b2a;
  --line:       rgba(245,240,232,0.10);

  --font-display: "Fraunces", Georgia, serif;
  --font-body:    "Inter", system-ui, -apple-system, sans-serif;

  --container: 1140px;
  --section-pad: clamp(64px, 9vw, 120px);
  --radius: 14px;
}

/* ============ RESET ============ */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; }
img,svg,video,iframe{ display:block; max-width:100%; }
a{ color:inherit; }
button{ font:inherit; }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; }
}

/* ============ BASE ============ */
body{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:900;
  line-height:1.08;
  margin:0;
  letter-spacing:-0.01em;
}
h2{ font-size:clamp(28px,4vw,42px); }
h3{ font-size:clamp(20px,2.4vw,26px); font-weight:600; }
p{ margin:0; color:var(--cream-dim); }

em{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:500;
  color:var(--gold);
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}
.section{ padding:var(--section-pad) 0; }

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:13px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 18px;
}
.eyebrow::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--rust);
  flex:none;
}

:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:4px;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:15px 30px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform 0.18s ease, background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--rust); color:var(--cream); }
.btn-primary:hover{ background:#d6592f; }
.btn-ghost{ background:transparent; border-color:var(--line); color:var(--cream); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); }
.btn-block{ width:100%; }
.btn-sm{ padding:11px 22px; font-size:13.5px; }

/* ============ HEADER ============ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(15,14,12,0.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between;
  height:76px;
}
.site-branding a{
  font-family:var(--font-display);
  font-weight:900;
  font-size:20px;
  text-decoration:none;
  color:var(--cream);
  letter-spacing:-0.01em;
}
.site-branding a span{ color:var(--gold); }

/* WordPress nav menu */
#primary-menu{
  display:flex; align-items:center; gap:34px;
  list-style:none; margin:0; padding:0;
}
#primary-menu a{
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  color:var(--cream-dim);
  transition:color 0.15s ease;
}
#primary-menu a:hover{ color:var(--cream); }
#primary-menu .current-menu-item a{ color:var(--cream); }

.nav-cta{ display:flex; align-items:center; gap:16px; }
.nav-toggle{
  display:none;
  background:none; border:1px solid var(--line); border-radius:8px;
  width:42px; height:42px;
  color:var(--cream);
  align-items:center; justify-content:center;
  cursor:pointer;
}
.nav-toggle svg{ width:20px; height:20px; }

@media (max-width:860px){
  #primary-menu{
    position:fixed; inset:76px 0 0 0;
    flex-direction:column; align-items:flex-start;
    gap:0;
    background:var(--ink);
    padding:20px 24px 40px;
    transform:translateY(-12px);
    opacity:0;
    visibility:hidden;
    transition:opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
  }
  #primary-menu a{
    width:100%; padding:16px 0;
    border-bottom:1px solid var(--line);
    font-size:17px;
    display:block;
  }
  #primary-menu.is-open{
    opacity:1; visibility:visible; transform:translateY(0);
  }
  .nav-cta .btn-ghost{ display:none; }
  .nav-toggle{ display:flex; }
}

/* ============ SPROCKET DIVIDER ============ */
.sprockets{
  height:22px;
  background-image:
    radial-gradient(circle at center, var(--ink) 3px, transparent 3.5px),
    linear-gradient(var(--gold), var(--gold));
  background-size: 28px 22px, 100% 1px;
  background-position: 14px center, center;
  background-repeat: repeat-x, no-repeat;
  opacity:0.55;
}

/* ============ HERO ============ */
.hero{
  padding-top:clamp(56px,8vw,96px);
  padding-bottom:clamp(56px,8vw,96px);
  overflow:hidden;
}
.hero .container{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:56px;
  align-items:center;
}
.hero h1{ font-size:clamp(36px,5.4vw,58px); }
.hero h1 .accent{ color:var(--gold); }
.hero-sub{ font-size:18px; margin-top:22px; max-width:50ch; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
.hero-note{ margin-top:20px; font-size:13px; color:var(--cream-dim); letter-spacing:0.04em; }
.hero-note strong{ color:var(--gold); }

.viewfinder{
  position:relative;
  border-radius:var(--radius);
  background:var(--ink-2);
  padding:14px;
}
.viewfinder-frame{
  position:relative;
  border-radius:8px;
  overflow:hidden;
  aspect-ratio:16/9;
  background:#000;
}
.viewfinder-frame iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0;
}
.corner{
  position:absolute; width:22px; height:22px;
  border:2px solid var(--gold);
  z-index:2;
}
.corner--tl{ top:-1px; left:-1px; border-right:0; border-bottom:0; }
.corner--tr{ top:-1px; right:-1px; border-left:0; border-bottom:0; }
.corner--bl{ bottom:-1px; left:-1px; border-right:0; border-top:0; }
.corner--br{ bottom:-1px; right:-1px; border-left:0; border-top:0; }
.viewfinder-bar{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 6px 2px;
  font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--cream-dim);
}
.rec{ display:inline-flex; align-items:center; gap:8px; color:var(--rust); font-weight:600; }
.rec::before{
  content:""; width:9px; height:9px; border-radius:50%;
  background:var(--rust);
  animation:pulse 1.6s infinite ease-in-out;
}
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:0.25; } }

@media (max-width:900px){
  .hero .container{ grid-template-columns:1fr; gap:40px; }
}

/* ============ PROBLEM / SOLUTION ============ */
.problem-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-bottom:56px;
}
.frame-card{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
}
.frame-card .frame-no{
  font-family:var(--font-display);
  font-weight:900;
  font-size:14px;
  color:var(--gold);
  letter-spacing:0.1em;
  display:block;
  margin-bottom:14px;
}
.frame-card h3{ margin-bottom:10px; }
.frame-card p{ font-size:15px; }

.solution-split{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:48px;
  align-items:start;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:40px;
}
.checklist{
  list-style:none; margin:22px 0 0; padding:0;
  display:flex; flex-direction:column; gap:14px;
}
.checklist li{
  display:flex; align-items:flex-start; gap:12px;
  font-size:15.5px; color:var(--cream);
}
.checklist li::before{
  content:"";
  flex:none;
  width:20px; height:20px; margin-top:2px;
  border-radius:50%;
  background-color:var(--gold);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f0e0c' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  background-size:12px 12px;
}
.stat-row{ display:flex; flex-direction:column; gap:24px; }
.stat{ border-left:2px solid var(--rust); padding-left:18px; }
.stat .stat-num{
  font-family:var(--font-display);
  font-weight:900;
  font-size:clamp(34px,4vw,46px);
  color:var(--gold);
  line-height:1;
}
.stat p{ margin-top:6px; font-size:14.5px; }

.offer-banner{
  margin-top:40px;
  display:flex; align-items:center; gap:16px;
  justify-content:space-between;
  flex-wrap:wrap;
  background:linear-gradient(135deg, var(--rust), var(--gold));
  border-radius:var(--radius);
  padding:22px 28px;
  color:var(--ink);
}
.offer-banner strong{ font-family:var(--font-display); font-size:19px; }
.offer-banner p{ color:rgba(15,14,12,0.78); font-size:14px; }
.offer-banner .btn-primary{ background:var(--ink); color:var(--cream); }
.offer-banner .btn-primary:hover{ background:#000; }

@media (max-width:900px){
  .problem-grid{ grid-template-columns:1fr; }
  .solution-split{ grid-template-columns:1fr; padding:28px; }
}

/* ============ PROCESS FILMSTRIP ============ */
.filmstrip{
  position:relative;
  background:var(--ink-3);
  border-radius:var(--radius);
  padding:34px 4px;
  display:grid;
  grid-template-columns:repeat(5,1fr);
}
.filmstrip::before,.filmstrip::after{
  content:"";
  position:absolute; left:0; right:0; height:16px;
  background-image:radial-gradient(circle at 14px center, var(--ink) 5px, transparent 5.5px);
  background-size:28px 16px;
  background-repeat:repeat-x;
  pointer-events:none;
}
.filmstrip::before{ top:0; border-radius:var(--radius) var(--radius) 0 0; }
.filmstrip::after{ bottom:0; border-radius:0 0 var(--radius) var(--radius); }
.frame{
  padding:0 22px;
  border-right:1px dashed var(--line);
  display:flex; flex-direction:column; gap:14px;
}
.frame:last-child{ border-right:0; }
.frame .frame-tag{
  font-family:var(--font-display);
  font-weight:900;
  font-size:34px;
  color:var(--gold);
  line-height:1;
}
.frame h3{ font-size:17px; }
.frame .duration{
  font-size:12px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--rust); font-weight:600;
}
.frame p{ font-size:14px; }

@media (max-width:980px){
  .filmstrip{ grid-template-columns:1fr; padding:24px; }
  .frame{
    padding:18px 0;
    border-right:0;
    border-bottom:1px dashed var(--line);
  }
  .frame:last-child{ border-bottom:0; }
}

/* ============ ABOUT ============ */
.about-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}
.about-wrap p + p{ margin-top:16px; }
.about-points{ display:flex; flex-direction:column; gap:22px; }
.about-point{ display:flex; gap:16px; align-items:flex-start; }
.about-point .dot{
  flex:none; width:38px; height:38px; border-radius:50%;
  background:var(--ink-2); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:900; color:var(--gold);
}
.about-point h3{ font-size:16px; margin-bottom:4px; }
.about-point p{ font-size:14.5px; }

@media (max-width:900px){
  .about-wrap{ grid-template-columns:1fr; gap:36px; }
}

/* ============ PRICING ============ */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  align-items:stretch;
}
.price-card{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:34px 28px;
  display:flex; flex-direction:column;
  position:relative;
}
.price-card--featured{
  border-color:var(--gold);
  background:linear-gradient(180deg, rgba(212,150,58,0.10), var(--ink-2) 40%);
  transform:translateY(-10px);
}
.price-tag{
  position:absolute; top:0; right:28px; transform:translateY(-50%);
  background:var(--gold); color:var(--ink);
  font-size:12px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase;
  padding:6px 14px; border-radius:999px;
}
.price-style{
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--rust); font-weight:600; margin-bottom:10px;
}
.price-card h3{ font-size:20px; margin-bottom:6px; }
.price-amount{
  font-family:var(--font-display); font-weight:900;
  font-size:40px; color:var(--cream); margin:6px 0 22px;
}
.price-amount span{ font-size:15px; font-weight:500; color:var(--cream-dim); }
.price-features{
  list-style:none; margin:0 0 28px; padding:0;
  display:flex; flex-direction:column; gap:11px;
  flex:1;
}
.price-features li{
  font-size:14.5px; color:var(--cream-dim);
  display:flex; gap:10px; align-items:flex-start;
}
.price-features li::before{ content:"—"; color:var(--gold); flex:none; }
.price-card form{ margin-top:10px; }
.price-pay-note{ text-align:center; margin-top:8px; font-size:12px; color:var(--cream-dim); }

@media (max-width:900px){
  .pricing-grid{ grid-template-columns:1fr; }
  .price-card--featured{ transform:none; order:-1; }
}
.pricing-note{ text-align:center; margin-top:32px; font-size:14px; color:var(--cream-dim); }

/* ============ CONTACT ============ */
.contact-wrap{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:56px;
}
.contact-card{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:36px;
}
.contact-card .btn{ margin-top:22px; }
.field{ margin-bottom:18px; }
.field label{
  display:block; font-size:13px; font-weight:600;
  letter-spacing:0.06em; text-transform:uppercase;
  color:var(--cream-dim); margin-bottom:8px;
}
.field input,.field select,.field textarea{
  width:100%;
  background:var(--ink);
  border:1px solid var(--line);
  border-radius:8px;
  padding:13px 14px;
  color:var(--cream);
  font-family:var(--font-body);
  font-size:15px;
  transition:border-color 0.15s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--gold); outline:none;
}
.field textarea{ min-height:120px; resize:vertical; }
.hp-field{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-msg{
  margin-top:16px; font-size:14px; display:none;
  border-radius:8px; padding:12px 14px;
}
.form-msg.is-success{ display:block; background:rgba(212,150,58,0.15); color:var(--gold); }
.form-msg.is-error{ display:block; background:rgba(194,75,42,0.15); color:#ff9d80; }

@media (max-width:900px){
  .contact-wrap{ grid-template-columns:1fr; gap:36px; }
}

/* ============ LEGAL PAGES ============ */
.page-hero{ padding:56px 0 32px; }
.page-hero p{ margin-top:14px; font-size:16px; max-width:640px; }
.legal{ max-width:740px; }
.legal .updated{ font-size:13px; color:var(--cream-dim); margin-bottom:36px; }
.legal h2{ font-size:clamp(20px,2.6vw,26px); margin:40px 0 14px; }
.legal h2:first-of-type{ margin-top:0; }
.legal p{ margin-bottom:14px; font-size:15.5px; }
.legal ul,.legal ol{ margin:0 0 14px; padding-left:22px; color:var(--cream-dim); font-size:15.5px; }
.legal li{ margin-bottom:8px; }
.legal a{ color:var(--gold); text-decoration:underline; }
.legal strong{ color:var(--cream); }
.legal .rule-box{
  background:var(--ink-2);
  border:1px solid var(--line);
  border-left:3px solid var(--gold);
  border-radius:var(--radius);
  padding:22px 24px;
  margin:0 0 36px;
}
.legal .rule-box p{ margin-bottom:10px; font-size:15.5px; }
.legal .rule-box p:last-child{ margin-bottom:0; }
.legal .rule-box strong{ color:var(--gold); }

/* ============ FOOTER ============ */
.site-footer{
  border-top:1px solid var(--line);
  padding:48px 0 32px;
}
.footer-wrap{
  display:flex; flex-wrap:wrap; justify-content:space-between;
  gap:24px; align-items:center;
}
.footer-links{
  display:flex; gap:24px; list-style:none; margin:0; padding:0; flex-wrap:wrap;
}
.footer-links a{ font-size:14px; color:var(--cream-dim); text-decoration:none; }
.footer-links a:hover{ color:var(--gold); }
.footer-meta{ font-size:13px; color:var(--cream-dim); margin-top:24px; }

/* ============ REVEAL ANIMATION ============ */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity 0.6s ease, transform 0.6s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* ============ WP ADMIN BAR FIX ============ */
.admin-bar .site-header{ top:32px; }
@media (max-width:782px){ .admin-bar .site-header{ top:46px; } }
