/* ============================================================
   HERO.CSS — Hero section + photo card + buttons
   ============================================================ */

.hero{padding:132px 0 80px;position:relative}
.hero .wrap{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(32px,5vw,72px);align-items:stretch}
.hero-left{display:flex;flex-direction:column;justify-content:space-between;min-height:560px;padding:12px 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--ink-soft);font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  margin-bottom:28px;
}
.eyebrow::before{content:"";display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--marigold);box-shadow:0 0 0 4px rgba(246,162,88,0.18)}
.eyebrow .sep{opacity:.35}
.hero h1{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(44px,6.2vw,86px);line-height:1.12;letter-spacing:-0.02em;color:var(--midnight);
  font-variation-settings:"opsz" 96;
}
.hero h1 em{font-style:italic}
.hero h1 .mark{position:relative;display:inline-block}
.hero h1 .mark::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:6%;height:18%;
  background:var(--marigold);opacity:.45;z-index:-1;border-radius:3px;transform:skewX(-4deg);
}
.hero-lede{font-size:clamp(16px,1.35vw,18px);color:var(--ink-soft);max-width:500px;margin-top:28px;line-height:1.65}
.hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}

/* Buttons (shared) */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;font-family:var(--sans);font-size:14px;font-weight:500;
  border:1.5px solid transparent;transition:all .25s;letter-spacing:-0.005em;cursor:pointer;
}
.btn.primary{background:var(--midnight);color:var(--lionsmane);border-color:var(--midnight)}
.btn.primary:hover{background:var(--marigold);border-color:var(--marigold);color:var(--midnight)}
.btn.ghost{color:var(--midnight);border-color:var(--rule-strong);background:transparent}
.btn.ghost:hover{border-color:var(--midnight);background:var(--midnight);color:var(--lionsmane)}
.btn .circle{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:rgba(252,243,227,0.16);font-size:11px}
.btn.ghost .circle{background:rgba(1,61,90,0.08)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}

/* Hero right (photo card) */
.hero-right{
  position:relative;background:var(--paper);border:1px solid var(--rule);border-radius:18px;
  padding:22px;display:flex;flex-direction:column;min-height:560px;
}
.hero-art{
  position:relative;flex:1;border-radius:10px;overflow:hidden;
  background:linear-gradient(135deg, var(--celeste) 0%, var(--celeste-soft) 100%);
}
.hero-art-blur{
  position:absolute;inset:-20px;
  background-size:cover;background-position:center;
  filter:blur(28px) saturate(1.3) brightness(0.85);
  transform:scale(1.1);
  display:none;
}
.hero-photo-layer{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;
  opacity:0;transition:opacity 1s ease;
}
.hero-photo-layer.active{opacity:1}
@media(prefers-reduced-motion:reduce){
  .hero-photo-layer{transition:opacity 0.1s ease}
}

.hero-art-fallback{
  position:absolute;inset:0;display:grid;place-items:center;
  background:
    linear-gradient(135deg, rgba(246,162,88,0.55), rgba(1,61,90,0.85)),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.05) 0 3px, transparent 3px 7px);
  color:var(--lionsmane);font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  text-align:center;padding:24px;
}
.hero-right .ticker{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-mute);
}
.hero-right .ticker .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--herb);margin-right:6px;vertical-align:middle;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-right .caption{padding-top:16px;border-top:1px solid var(--rule);margin-top:16px;display:flex;justify-content:space-between;align-items:baseline}
.hero-right .caption .ctitle{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--midnight)}
.hero-right .caption .cmeta{font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-mute)}
.hero-photo-tag{
  position:absolute;left:14px;top:14px;
  background:rgba(252,243,227,0.92);backdrop-filter:blur(6px);
  padding:5px 10px;border-radius:999px;
  font-family:var(--mono);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--midnight);
}

/* Responsive */
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:36px}
  .hero-left{min-height:auto}
  .hero-right{min-height:420px}
}
