/* === JP Digital — Main Styles ========================================= */
/* Variables */
:root{
  --crimson:#682125;
  --gold:#FFD700;
  --cyan:#00d2ff;

  --bg:#0b0f14;
  --panel:#0f1115;
  --panel-2:#111216;
  --muted:#9aa0a6;

  --border:rgba(255,255,255,.08);
  --border-2:rgba(255,255,255,.12);
  --glass:rgba(15,17,21,.55);

  --header-h:72px;
}

/* Base reset */
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
html,body{margin:0;padding:0;background:var(--bg);color:#eef2f6}
body{font-family:"Montserrat",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.6}
h1,h2,h3,h4{font-family:"Cinzel",serif;margin:0 0 .6rem 0;line-height:1.2}
h1{font-weight:800}
h2{font-size:clamp(24px,3.2vw,28px)}
a{color:var(--cyan);text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.row{display:flex;align-items:center}
.gap{gap:12px}
.small{font-size:.95rem}
.muted{color:var(--muted)}

/* Accessibility */
a:focus-visible,button:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:8px}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:20px;top:10px;width:auto;height:auto;z-index:9999;background:#000;color:#fff;padding:8px 10px;border-radius:8px}

/* Header / Nav */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(10,10,12,.6);
  border-bottom:1px solid var(--border);
}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;min-height:var(--header-h)}

.brand{display:flex;align-items:center;gap:.6rem;font-weight:700}
.logo{height:18px;width:auto;vertical-align:-3px;opacity:.9}
.brand-word{font-family:"Cinzel",serif;font-weight:800;letter-spacing:.3px;color:var(--cyan)}

#site-nav{display:flex;align-items:center}
#site-nav a{margin-left:18px;color:#e8eaed;padding:10px 12px;position:relative}
#site-nav a.btn{margin-left:24px}

/* Buttons */
.btn{display:inline-block;padding:10px 16px;border:1px solid rgba(255,255,255,.2);border-radius:12px;transition:transform .15s ease,box-shadow .15s ease}
.btn.primary{background:linear-gradient(135deg,var(--crimson),#4d1017);border:none;color:#fff;box-shadow:0 10px 30px rgba(104,33,37,.35)}
.btn.primary:hover{transform:translateY(-1px)}
.btn.ghost{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.35)}
.btn.small{padding:8px 14px;font-size:.95rem}

/* Mobile toggle */
.menu-toggle{display:none;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid rgba(255,255,255,.25);border-radius:10px;background:transparent}
.menu-toggle .bar{display:block;width:20px;height:2px;background:#e8eaed;margin:3px 0;border-radius:2px}

/* Hero */
.hero{
  padding:90px 0 40px;
  background:
    radial-gradient(1200px 600px at 70% -20%, rgba(0,224,255,.15), transparent),
    radial-gradient(1000px 500px at -20% 10%, rgba(255,215,0,.08), transparent)
}
.hero-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.hero h1{font-size:clamp(36px,5vw,56px);color:#fff}
.hero p{color:#e6e6e6;margin-bottom:10px}
.cta{display:flex;gap:14px;margin-top:10px}
.muted.small{color:var(--muted);font-size:.95rem;margin-top:6px}

/* Hero art (square logo card) */
.hero-art{position:relative;min-height:520px}
.orb{position:absolute;inset:0;background:
  radial-gradient(circle at 30% 30%, rgba(0,224,255,.5), transparent 40%),
  radial-gradient(circle at 70% 70%, rgba(255,215,0,.35), transparent 45%);filter:blur(40px)}
.chip{
  position:absolute;right:10%;top:12%;
  width:420px;height:420px; /* perfect square */
  padding:8px;display:flex;align-items:center;justify-content:center;
  border-radius:16px;border:1px solid var(--border);
  background:var(--glass);backdrop-filter: blur(6px) saturate(1.05);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04),0 10px 30px rgba(0,0,0,.35);overflow:hidden
}
.chip::after{
  content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(255,215,0,.35);
  box-shadow:0 0 14px rgba(255,215,0,.25), inset 0 0 10px rgba(255,215,0,.12);
  opacity:.18;transform:scale(1);animation:goldPulse 5.5s ease-in-out infinite;z-index:0
}
.chip img{width:75%;height:75%;object-fit:contain;position:relative;z-index:1}
@keyframes goldPulse{0%,100%{opacity:.18;transform:scale(1)}50%{opacity:.45;transform:scale(1.02)}}

/* Sections */
.section{padding:70px 0}
.section.alt{background:#0f0f12}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:18px}
.card{background:var(--panel-2);border:1px solid var(--border);border-radius:18px;padding:20px}
.card h3{font-weight:700;font-size:1.05rem;letter-spacing:.02em}
.card ul{margin:0;padding-left:18px}

.process{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px}
.process .step{background:#101217;border:1px solid var(--border);border-radius:18px;padding:18px}
.process .num{width:32px;height:32px;border-radius:999px;background:linear-gradient(135deg,var(--cyan),var(--gold));display:flex;align-items:center;justify-content:center;color:#000;font-weight:700;margin-bottom:8px}

/* Pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:18px}
.price-card{background:var(--panel-2);border:1px solid var(--border);border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:10px}
.price-card .pill{display:inline-block;font-size:.9rem;color:var(--gold)}
.price-card .price{font-size:32px;font-weight:700}
.price-card.featured{border-color:var(--gold);box-shadow:0 10px 30px rgba(255,215,0,.12)}

/* Work grid */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.work{background:var(--panel-2);border:1px solid var(--border);border-radius:18px;overflow:hidden;display:block}
.work .thumb{height:140px;background:linear-gradient(135deg, rgba(0,224,255,.25), rgba(104,33,37,.35))}
.work-title{padding:12px;color:#fff;display:flex;align-items:center;gap:8px}
.work-title .ext{opacity:.8}

/* Trust */
.trust-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.trust-item{background:var(--panel-2);border:1px solid var(--border);border-radius:18px;padding:18px}
.trust-item blockquote{margin:0 0 8px 0;font-style:italic}
.trust-item .who{color:var(--muted)}

/* CTA strip */
.cta-banner{background:linear-gradient(135deg, rgba(104,33,37,.55), rgba(0,224,255,.25));padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-banner .row{display:flex;align-items:center;justify-content:space-between;gap:10px}

/* Footer */
.site-footer{background:#0f0f12;border-top:1px solid var(--border);margin-top:60px;padding-top:34px}
.site-footer .grid-3{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:28px;padding:26px 0}
.site-footer h4{color:var(--gold)}
.site-footer .muted{color:var(--muted)}
.site-footer .small{font-size:.9rem;opacity:.9}
.site-footer ul{padding-left:18px}
.site-footer a:hover{text-decoration:underline}
.copyright{border-top:1px solid var(--border);padding:12px 0;text-align:center;color:#b7bcc3;font-size:.95rem}
.text-link{color:#cfe9ff}

/* Back to Top */
.to-top{
  position:fixed;right:18px;bottom:18px;z-index:60;
  width:44px;height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.25);
  background:rgba(15,17,21,.75);color:#fff;font-size:20px;line-height:1;
  display:none;align-items:center;justify-content:center;
  box-shadow:0 10px 20px rgba(0,0,0,.3);backdrop-filter:blur(6px)
}
.to-top.show{display:flex}

/* Custom Scroll Rail */
.scroll-rail{
  position:fixed;right:6px;top:calc(var(--header-h) + 6px);bottom:8px;z-index:40;
  width:8px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  pointer-events:none; /* rail itself not clickable; thumb is */
}
.scroll-thumb{
  position:absolute;left:0;top:0;right:0;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.18);
  background:linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.08));
  box-shadow:0 2px 10px rgba(0,0,0,.35);
  pointer-events:auto;cursor:grab;transition:transform .06s linear;
}
.scroll-thumb.drag{cursor:grabbing}

/* Responsive */
@media (max-width:1200px){ .site-footer .grid-3{grid-template-columns:1fr 1fr} }
@media (max-width:700px){ .site-footer .grid-3{grid-template-columns:1fr} }

@media (max-width:960px){
  :root{--header-h:60px}
  .site-header .nav{min-height:60px}
  .logo{height:16px}
  .brand-word{font-size:1rem}

  .menu-toggle{display:flex}

  /* Mobile menu: hidden by default, shown when .open */
  #site-nav{
    position:fixed;top:var(--header-h);left:0;right:0;display:none;flex-direction:column;
    background:#0f0f12F2;backdrop-filter:blur(10px);border-top:1px solid var(--border);box-shadow:0 12px 30px rgba(0,0,0,.4);z-index:40
  }
  #site-nav.open{display:flex}
  #site-nav a{margin:0;padding:14px 20px;border-bottom:1px solid var(--border);font-size:1.05rem}
  #site-nav a.btn{margin:10px 16px 14px;align-self:flex-start}

  .hero{padding:70px 0 28px}
  .hero h1{font-size:clamp(30px,8vw,40px)}
  .hero-inner{grid-template-columns:1fr}
  .chip{width:260px;height:260px;right:4%;top:8%}

  .cards,.pricing,.process,.work-grid,.trust-wrap{grid-template-columns:1fr}
}

/* Safety overrides (do not remove) */
body.nav-open{overflow:auto !important;} /* never lock the page */
.scroll-thumb{will-change:transform;touch-action:none;} /* smooth drag */

/* Keep burger above the slide-down nav so a 2nd click closes it */
.menu-toggle{ position: relative; z-index: 2001; }
#site-nav{ z-index: 2000; }

/* Never lock page scroll even if some old code toggles these classes */
body.nav-open, body.menu-open, body.no-scroll, body.lock-scroll { overflow: auto !important; }

/* When the mobile menu is closed, don't let the invisible layer catch scroll/taps */
@media (max-width:960px){
  #site-nav { pointer-events: none; }
  #site-nav.open { pointer-events: auto; }
}
/* Hidden menu should not capture taps/scroll */
@media (max-width:960px){
  #site-nav { pointer-events: none; }
  #site-nav.open { pointer-events: auto; }
}

/* Never lock page scroll even if an old class gets toggled */
body.nav-open, body.menu-open, body.no-scroll, body.lock-scroll { overflow: auto !important; }

/* === Header brand: favicon + gold wordmark ============================== */
.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

/* New small icon (favicon) */
.brand .brand-icon {
  width: 24px;
  height: 24px;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 0 4px rgba(255,215,0,0.25)); /* subtle glow */
}

/* Header wordmark: deeper gold (not neon) */
.brand .brand-word{
  color:#D4AF37 !important;               /* rich metallic gold */
  text-shadow:
    0 0 0 rgba(0,0,0,0),                  /* reset any old shadow */
    0 1px 0 rgba(0,0,0,.25),              /* subtle weight */
    0 0 10px rgba(212,175,55,.12);        /* soft glow */
}

}

/* Optional: if the old .logo is still in the markup, hide it */
.brand .logo { display: none; }

/* Header wordmark: metallic gradient gold */
.brand .brand-word{
  background-image: linear-gradient(
    180deg,
    #F7E7A9 0%,
    #E8C766 38%,
    #D4AF37 60%,
    #B9972E 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent !important;
  text-shadow:
    0 1px 0 rgba(0,0,0,.25),
    0 0 8px rgba(212,175,55,.14);
}
