/*
Theme Name: PennCrest
Theme URI: https://penncrest.local/
Author: Yellow Blue IT
Author URI: https://yellowblueit.com/
Description: Custom marketing theme for PennCrest, an AI-enabled insurance brokerage. Five page templates (Home, Partners, Platform, About, Careers) plus a default. Editable hero copy and stats via the page editor and Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: Proprietary
License URI: https://penncrest.local/license
Text Domain: penncrest
*/

*{margin:0;padding:0;box-sizing:border-box}
:root{--red:#d63027;--red-dark:#b32820;--red-light:#fdf1f0;--ink:#1e1e1e;--ink2:#484848;--ink3:#909090;--bg:#ffffff;--charcoal:#1e1e1e;--border:rgba(30,30,30,0.1);--card:#ffffff}
body{font-family:'DM Sans',sans-serif;background:#ffffff;color:var(--ink)}
nav{display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;height:68px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.nav-logo{cursor:pointer;display:block;width:160px;height:auto}
.nav-links{display:flex;gap:0.15rem}
.nav-link{font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:400;padding:0.4rem 0.9rem;border-radius:4px;cursor:pointer;color:var(--ink2);background:none;border:none;transition:all 0.15s}
.nav-link:hover{background:rgba(30,30,30,0.06);color:var(--ink)}
.nav-link.active{background:var(--charcoal);color:#fff}
.nav-cta{font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:500;padding:0.45rem 1.3rem;border-radius:4px;background:var(--red);color:#fff;cursor:pointer;border:none}
.nav-cta:hover{background:var(--red-dark)}
/* page wrapper - always visible since each WP page is its own URL */
.page{display:block}
.wrap{max-width:1100px;margin:0 auto;padding:0 2.5rem}
.section{padding:5rem 0}
.label{font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);margin-bottom:0.6rem}
.label-light{color:#d68080}
h1{font-family:'DM Sans',sans-serif;font-weight:600;font-size:clamp(2.6rem,5vw,4.4rem);line-height:1.08;letter-spacing:-0.03em;color:var(--ink);margin-bottom:1.5rem;max-width:860px}
h1 em{font-style:normal;color:var(--red)}
h2{font-family:'DM Sans',sans-serif;font-weight:600;font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.1;letter-spacing:-0.03em;color:var(--ink);margin-bottom:1rem}
h2.light{color:#fff}
h3{font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.5rem;letter-spacing:-0.02em;line-height:1.2;color:var(--ink);margin-bottom:1rem}
h3.light{color:#fff}
h4{font-family:'DM Sans',sans-serif;font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:0.4rem}
.body{font-size:1rem;font-weight:300;color:var(--ink2);line-height:1.75;max-width:620px}
.body-light{color:rgba(255,255,255,0.55)}
.btn-primary{font-family:'DM Sans',sans-serif;font-weight:500;padding:0.65rem 1.8rem;border-radius:4px;background:var(--red);color:#fff;font-size:0.95rem;cursor:pointer;border:none}
.btn-primary:hover{background:var(--red-dark)}
.btn-ghost{font-family:'DM Sans',sans-serif;font-weight:500;padding:0.65rem 1.8rem;border-radius:4px;background:none;color:var(--ink);font-size:0.95rem;cursor:pointer;border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--ink)}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:3rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-top:3rem}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:3rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1.75rem}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(30,30,30,0.07);transition:all 0.2s}
.card-dark{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:1.75rem}
.icon{width:36px;height:36px;border-radius:6px;background:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:1rem}
.pill{display:inline-block;font-size:0.72rem;font-weight:400;letter-spacing:0.05em;text-transform:uppercase;padding:0.2rem 0.6rem;border-radius:3px;background:var(--red-light);color:var(--red);margin-bottom:0.75rem}
.tag{display:inline-block;font-size:0.72rem;font-weight:400;letter-spacing:0.06em;text-transform:uppercase;padding:0.2rem 0.7rem;border-radius:3px;margin-bottom:1rem}
.hero-stats{display:flex;gap:3rem;margin-top:4rem;padding-top:3rem;border-top:1px solid var(--border);flex-wrap:wrap}
.stat-num{font-family:'DM Sans',sans-serif;font-size:2.2rem;font-weight:600;color:var(--ink);line-height:1}
.stat-label{font-size:0.8rem;color:var(--ink3);margin-top:0.3rem}
.dark-band{background:var(--charcoal);padding:5rem 0}
.darker-band{background:#1a1a1a;padding:5rem 0}
.comp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2.5rem}
.comp-card{border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:1.5rem}
.step-timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}
.step-item{border-left:2px solid var(--red);padding-left:1.25rem}
.step-week{font-family:'DM Sans',sans-serif;font-weight:600;font-size:0.8rem;color:rgba(255,255,255,0.4);margin-bottom:0.4rem}
.step-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:1rem;color:#fff;margin-bottom:0.4rem}
.step-body{font-size:0.84rem;font-weight:300;color:rgba(255,255,255,0.5);line-height:1.6}
.value-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem}
.value-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0;margin-top:7px}
.job-card{border:1px solid var(--border);border-radius:8px;padding:1.4rem 1.75rem;background:var(--card);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all 0.2s;margin-bottom:1rem}
.job-card:hover{border-color:var(--red);transform:translateX(4px)}
.job-dept{font-size:0.72rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);margin-bottom:0.25rem}
.resource-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--card);cursor:pointer;transition:all 0.2s}
.resource-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(30,30,30,0.08)}
.resource-img{height:120px;display:flex;align-items:center;justify-content:center;font-size:2.2rem}
.resource-body{padding:1.25rem}
.resource-type{font-size:0.72rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);margin-bottom:0.35rem}
.eyebrow{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.78rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);margin-bottom:1.25rem}
.eyebrow::before{content:'';width:28px;height:2px;background:var(--red);display:inline-block}
.actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.acq-card{border:1px solid var(--border);border-radius:8px;padding:2rem;background:var(--card);margin-top:2rem}
.big-quote{font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.8rem;line-height:1.2;letter-spacing:-0.02em;color:var(--ink);margin-bottom:1.5rem;border-left:4px solid var(--red);padding-left:1.25rem}
.time-box{background:var(--charcoal);border-radius:8px;padding:2rem}
.time-row{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,0.08);padding-bottom:1rem;margin-bottom:1rem}
.time-label{font-size:0.88rem;font-weight:300;color:rgba(255,255,255,0.55)}
.time-val{font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.4rem;color:#fff}
.cta-band{background:var(--charcoal);border-radius:8px;padding:2.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;margin-top:2rem}
footer{background:var(--charcoal);color:rgba(255,255,255,0.4);font-size:0.8rem;text-align:center;padding:1.5rem;font-weight:300}
footer span{color:rgba(255,255,255,0.8);font-weight:500}
@media(max-width:700px){.grid-2{grid-template-columns:1fr}}

/* ── Page transitions ── */
.page { animation: pageFadeIn 0.4s ease both; }
@keyframes pageFadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* ── Card hover lift ── */
.card, .card-dark, .resource-card, .job-card, .acq-card {
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.card:hover, .resource-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(30,30,30,0.10);
}
.job-card:hover { transform: translateX(5px); }

/* ── Scroll reveal ── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ── Red line draw ── */
.red-line {
  width: 0;
  height: 2px;
  background: var(--red);
  transition: width 0.7s ease 0.3s;
}
.red-line.visible { width: 40px; }

/* ── Nav scroll blur ── */
nav {
  transition: box-shadow 0.3s ease, background 0.3s ease;
}
nav.scrolled {
  box-shadow: 0 2px 24px rgba(30,30,30,0.10);
  backdrop-filter: blur(8px);
}

/* ── Ken Burns hero ── */
.hero-bg-img {
  animation: kenBurns 18s ease-in-out infinite alternate;
}
@keyframes kenBurns {
  from { transform: scale(1); }
  to   { transform: scale(1.06); }
}

/* ── Pulse dot ── */
.pulse-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
  margin-right: 6px;
  position: relative;
  flex-shrink: 0;
  margin-top: 7px;
}
.pulse-dot::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 2px solid var(--red);
  animation: pulse 1.6s ease-out infinite;
  opacity: 0;
}
@keyframes pulse {
  0%   { transform: scale(0.8); opacity: 0.7; }
  100% { transform: scale(2);   opacity: 0; }
}

/* ── Word-by-word headline reveal ── */
.word-reveal span {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.word-reveal.visible span { opacity: 1; transform: translateY(0); }

/* ── Clip reveal (text slides up through mask) ── */
.clip-reveal {
  overflow: hidden;
}
.clip-reveal-inner {
  display: block;
  transform: translateY(100%);
  transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.clip-reveal.visible .clip-reveal-inner {
  transform: translateY(0);
}

/* ── Label slide in ── */
.label-reveal {
  opacity: 0;
  transform: translateX(-10px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.label-reveal.visible {
  opacity: 1;
  transform: translateX(0);
}

/* ── Stagger bullets ── */
.stagger-item {
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.stagger-item.visible { opacity: 1; transform: translateX(0); }
