/* Page-specific styles for /broadcast-playbook/ + /broadcast-playbook/r/[slug]/.
   Inherits global tokens (--navy, --teal, --cyan, --gradient, fonts) from /styles.css. */

.bp-stage{padding:6.5rem 1.5rem 4rem;max-width:1180px;margin:0 auto}
@media(max-width:880px){.bp-stage{padding:5.5rem 1rem 3rem}}

/* ── HERO + URL INPUT (index.html only) ──────────────────────────── */
.bp-eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;border-radius:999px;background:var(--gradient-subtle);border:1px solid rgba(0,180,216,.18);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--teal);margin-bottom:1rem}
.bp-eyebrow .dot{width:6px;height:6px;border-radius:999px;background:var(--gradient);box-shadow:0 0 0 4px rgba(0,180,216,.12)}
.bp-title{font-family:'Source Serif 4',serif;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.08;letter-spacing:-.02em;font-weight:600;color:var(--navy);text-wrap:balance;margin:0 0 1rem}
.bp-title .ital{font-style:italic;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.bp-sub{font-size:1.05rem;color:var(--text-secondary);max-width:680px;line-height:1.65;margin:0 0 2rem}

.bp-form{display:flex;gap:.5rem;max-width:560px;margin-bottom:1rem;flex-wrap:wrap}
.bp-form input[type="url"]{flex:1;min-width:240px;font:inherit;font-size:1rem;color:var(--navy);background:#fff;border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem;transition:border-color .2s,box-shadow .2s}
.bp-form input[type="url"]:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,180,216,.18)}
.bp-form button{appearance:none;border:0;background:var(--gradient);color:#fff;font:inherit;font-size:1rem;font-weight:700;padding:.85rem 1.4rem;border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 6px 18px rgba(0,180,216,.28);transition:transform .2s,box-shadow .2s,opacity .2s;white-space:nowrap}
.bp-form button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,180,216,.35)}
.bp-form button:disabled{opacity:.6;cursor:not-allowed}
.bp-form button svg{width:18px;height:18px}
.bp-form-meta{font-size:.82rem;color:var(--text-light);max-width:560px}

/* ── PROGRESS RAIL ──────────────────────────────────────────────── */
.bp-progress{display:grid;gap:.4rem;margin:1.25rem 0 2rem;max-width:680px}
.bp-progress-step{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;border-radius:12px;border:1px solid var(--border-light);background:var(--white);font-size:.88rem;color:var(--text-secondary);transition:all .25s}
.bp-progress-step .num{width:22px;height:22px;border-radius:999px;background:var(--bg);border:1px solid var(--border);font-size:.75rem;font-weight:700;color:var(--text-light);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.bp-progress-step.active{border-color:rgba(0,180,216,.28);background:var(--gradient-subtle);color:var(--navy);font-weight:600}
.bp-progress-step.active .num{background:var(--gradient);color:#fff;border-color:transparent;animation:bpPulse 1.2s ease-in-out infinite}
.bp-progress-step.done .num{background:var(--cyan);color:#fff;border-color:transparent}
.bp-progress-step.done{color:var(--navy);opacity:.85}
.bp-progress-step.error .num{background:#dc2626;color:#fff;border-color:transparent}
.bp-progress-step.error{border-color:#fecaca;background:#fef2f2;color:#7f1d1d}
@keyframes bpPulse{0%,100%{box-shadow:0 0 0 0 rgba(0,180,216,.4)}50%{box-shadow:0 0 0 6px rgba(0,180,216,0)}}

/* ── BUSINESS SUMMARY HEADER ────────────────────────────────────── */
.bp-summary{padding:1.75rem;border-radius:18px;background:linear-gradient(170deg,#0a1628,#162035);color:#fff;margin-bottom:2rem;position:relative;overflow:hidden}
.bp-summary::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 100% 0%,rgba(0,180,216,.18),transparent 70%);pointer-events:none}
.bp-summary > *{position:relative;z-index:1}
.bp-summary .label{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin:0 0 .5rem}
.bp-summary h2{font-family:'Source Serif 4',serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:600;color:#fff;margin:0 0 .5rem;letter-spacing:-.01em;line-height:1.2}
.bp-summary .one-liner{font-size:1.02rem;color:rgba(255,255,255,.86);margin:0 0 1.25rem;line-height:1.55;max-width:740px}
.bp-summary-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:720px){.bp-summary-meta{grid-template-columns:1fr 1fr}}
.bp-summary-meta div{padding:.85rem 1rem;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.bp-summary-meta .key{display:block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:.3rem}
.bp-summary-meta .val{display:block;font-size:.92rem;color:#fff;line-height:1.4}

/* ── CALCULATOR ─────────────────────────────────────────────────── */
.bp-section{margin-bottom:2.75rem}
.bp-section-head{display:flex;align-items:flex-end;gap:.85rem;margin:0 0 1rem;flex-wrap:wrap}
.bp-section-head .num{font-family:'Source Serif 4',serif;font-size:1rem;font-weight:600;color:var(--teal);padding:.25rem .65rem;border-radius:8px;background:var(--gradient-subtle);border:1px solid rgba(0,180,216,.18);letter-spacing:.04em}
.bp-section-head h2{font-family:'Source Serif 4',serif;font-size:clamp(1.5rem,2.6vw,1.95rem);font-weight:600;color:var(--navy);margin:0;line-height:1.2}
.bp-section-desc{margin:0 0 1.5rem;color:var(--text-secondary);font-size:.98rem;max-width:680px;line-height:1.6}

.bp-calc{display:grid;grid-template-columns:300px 1fr;gap:1.5rem;padding:1.5rem;border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 8px 28px rgba(10,22,40,.04)}
@media(max-width:880px){.bp-calc{grid-template-columns:1fr}}

.bp-slider-group{margin-bottom:1.25rem}
.bp-slider-group:last-child{margin-bottom:0}
.bp-slider-group label{display:flex;justify-content:space-between;align-items:baseline;font-size:.85rem;font-weight:600;color:var(--navy);margin-bottom:.5rem}
.bp-slider-val{font-family:'Source Serif 4',serif;font-weight:600;color:var(--teal);font-size:1.05rem}
.bp-slider-group input[type="range"]{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;background:var(--border-light);outline:none}
.bp-slider-group input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gradient);cursor:pointer;box-shadow:0 2px 6px rgba(0,180,216,.4);border:2px solid #fff}
.bp-slider-group input[type="range"]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#00b4d8;cursor:pointer;border:2px solid #fff}
.bp-slider-group .hint{font-size:.75rem;color:var(--text-light);margin-top:.4rem}

.bp-calc-results{display:grid;grid-template-columns:repeat(4,1fr);gap:.65rem}
@media(max-width:880px){.bp-calc-results{grid-template-columns:repeat(2,1fr)}}
.bp-calc-card{padding:.85rem;border-radius:12px;background:var(--bg);border:1px solid var(--border-light);text-align:left}
.bp-calc-card .v{display:block;font-family:'Source Serif 4',serif;font-size:1.35rem;font-weight:600;color:var(--navy);line-height:1.1}
.bp-calc-card .l{display:block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-top:.35rem}
.bp-calc-card.highlight{background:var(--gradient-subtle);border-color:rgba(0,180,216,.24)}
.bp-calc-card.highlight .v{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

.bp-calc-note{grid-column:1 / -1;font-size:.78rem;color:var(--text-light);padding:.6rem .8rem;border-left:2px solid var(--border);background:var(--bg);border-radius:0 8px 8px 0;margin-top:.4rem;line-height:1.5}

/* ── CAMPAIGN CARDS GRID ────────────────────────────────────────── */
.bp-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:1080px){.bp-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.bp-cards{grid-template-columns:1fr}}

.bp-card{padding:1.25rem;border-radius:16px;border:1px solid var(--border);background:#fff;display:flex;flex-direction:column;gap:.75rem;transition:transform .25s ease,border-color .2s ease,box-shadow .2s ease;animation:bpCardIn .5s cubic-bezier(.22,1,.36,1) backwards}
.bp-card:hover{border-color:rgba(0,180,216,.22);box-shadow:0 8px 24px rgba(10,22,40,.05);transform:translateY(-1px)}
@keyframes bpCardIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.bp-card-skeleton{position:relative;min-height:280px;overflow:hidden}
.bp-card-skeleton::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(0,180,216,.08),transparent);animation:bpShimmer 1.6s linear infinite}
.bp-card-skeleton > *{opacity:.32}
@keyframes bpShimmer{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

.bp-card-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.bp-card-month{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light)}
.bp-card-month b{color:var(--teal);font-weight:700}
.bp-card-tag{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.25rem .55rem;border-radius:999px}
.bp-card-tag .e{font-size:.85rem}
.bp-tag-promotion{background:rgba(220,76,53,.10);color:#b53620}
.bp-tag-education{background:rgba(46,109,164,.12);color:#2a5e8e}
.bp-tag-story{background:rgba(123,94,167,.12);color:#5b3f86}
.bp-tag-reactivation{background:rgba(184,115,51,.14);color:#8a5520}
.bp-tag-seasonal{background:rgba(30,140,62,.12);color:#206b2f}
.bp-tag-lifecycle{background:rgba(26,138,125,.12);color:#106b62}

.bp-card h3{font-family:'Source Serif 4',serif;font-size:1.1rem;font-weight:600;color:var(--navy);margin:0;line-height:1.3;letter-spacing:-.005em}
.bp-card-meta{display:grid;gap:.4rem;font-size:.82rem;color:var(--text-secondary);line-height:1.5}
.bp-card-meta b{color:var(--navy);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.1rem}

.bp-card-copy{padding:.85rem;border-radius:10px;background:#0b1424;color:rgba(255,255,255,.92);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;line-height:1.55;white-space:pre-wrap;word-wrap:break-word;border:1px solid rgba(255,255,255,.05);max-height:280px;overflow-y:auto}
.bp-card-copy strong{color:#fff;font-weight:700}
.bp-card-copy em{color:rgba(255,255,255,.78);font-style:italic}

.bp-card-cta{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:var(--navy);padding:.55rem .8rem;border-radius:8px;background:var(--gradient-subtle);border:1px solid rgba(0,180,216,.2);align-self:flex-start}
.bp-card-cta .arrow{color:var(--teal);font-weight:700}
.bp-card-cta .hint{color:var(--text-light);font-weight:400;font-size:.78rem}

.bp-card-img{font-size:.78rem;color:var(--text-light);line-height:1.5;padding:.65rem .8rem;border-radius:10px;background:rgba(0,180,216,.04);border:1px solid rgba(0,180,216,.1)}
.bp-card-img b{display:block;color:var(--navy);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.3rem}

.bp-card-impact{font-size:.78rem;color:var(--text-light);font-style:italic;line-height:1.5;padding-top:.5rem;border-top:1px solid var(--border-light)}

/* ── CONTACT FORM (index.html, mid-stream) ──────────────────────── */
.bp-contact-card{position:fixed;bottom:1.5rem;right:1.5rem;width:360px;max-width:calc(100vw - 2rem);padding:1.25rem;border-radius:16px;background:#fff;border:1px solid var(--border);box-shadow:0 16px 48px rgba(10,22,40,.16);z-index:80;animation:bpSlideIn .45s cubic-bezier(.22,1,.36,1)}
@keyframes bpSlideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.bp-contact-card h3{font-family:'Source Serif 4',serif;font-size:1.05rem;font-weight:600;color:var(--navy);margin:0 0 .25rem}
.bp-contact-card .lede{font-size:.85rem;color:var(--text-secondary);margin:0 0 1rem;line-height:1.5}
.bp-contact-field{margin-bottom:.65rem}
.bp-contact-field label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light);margin-bottom:.25rem}
.bp-contact-field input,.bp-contact-field select{width:100%;font:inherit;font-size:.92rem;color:var(--navy);background:#fff;border:1px solid var(--border);border-radius:8px;padding:.55rem .7rem;transition:border-color .2s,box-shadow .2s}
.bp-contact-field input:focus,.bp-contact-field select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,180,216,.16)}
.bp-contact-phone-row{display:grid;grid-template-columns:96px 1fr;gap:.4rem}
.bp-contact-cta{appearance:none;border:0;width:100%;background:var(--gradient);color:#fff;font:inherit;font-size:.92rem;font-weight:700;padding:.7rem 1rem;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.4rem;box-shadow:0 4px 14px rgba(0,180,216,.28);transition:transform .2s,opacity .2s}
.bp-contact-cta:hover:not(:disabled){transform:translateY(-1px)}
.bp-contact-cta:disabled{opacity:.6;cursor:not-allowed}
.bp-contact-fine{font-size:.7rem;color:var(--text-light);margin:.5rem 0 0;line-height:1.5}
.bp-contact-card.captured{display:none}
.bp-contact-card-close{position:absolute;top:.5rem;right:.5rem;background:transparent;border:0;color:var(--text-light);cursor:pointer;padding:.3rem;border-radius:6px;font-size:1.1rem}
.bp-contact-card-close:hover{background:var(--bg);color:var(--navy)}
.bp-contact-success{display:none;font-size:.85rem;color:#106b62;background:rgba(46,109,164,.06);border:1px solid rgba(26,138,125,.18);border-radius:8px;padding:.55rem .7rem;margin-top:.4rem}
.bp-contact-card.success .bp-contact-fields,.bp-contact-card.success .bp-contact-cta,.bp-contact-card.success .bp-contact-fine{display:none}
.bp-contact-card.success .bp-contact-success{display:block}

@media(max-width:720px){
  .bp-contact-card{position:static;width:100%;margin:1rem 0 0}
}

/* ── REPORT VIEWER STICKY CTA ───────────────────────────────────── */
.bp-sticky-cta{position:fixed;bottom:1.25rem;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:.85rem 1.25rem;border-radius:14px;font-size:.92rem;font-weight:600;display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;box-shadow:0 12px 36px rgba(10,22,40,.28);z-index:80;transition:transform .2s,box-shadow .2s}
.bp-sticky-cta:hover{transform:translateX(-50%) translateY(-2px);box-shadow:0 16px 44px rgba(10,22,40,.36)}
.bp-sticky-cta .icon{width:18px;height:18px;color:var(--cyan)}
.bp-sticky-cta .arrow{margin-left:.2rem}
.bp-sticky-cta .pdf{margin-left:.65rem;padding-left:.85rem;border-left:1px solid rgba(255,255,255,.18);font-weight:500;font-size:.82rem;color:rgba(255,255,255,.78);cursor:pointer;background:transparent;border-radius:0;border-top:0;border-right:0;border-bottom:0}
.bp-sticky-cta .pdf:hover{color:#fff}

@media(max-width:560px){
  .bp-sticky-cta{left:.75rem;right:.75rem;transform:none;justify-content:center}
  .bp-sticky-cta:hover{transform:translateY(-2px)}
}

/* ── REPORT VIEWER LOADING / ERROR ──────────────────────────────── */
.bp-state-card{padding:2rem;border-radius:18px;background:#fff;border:1px solid var(--border);text-align:center;max-width:560px;margin:3rem auto}
.bp-state-card h2{font-family:'Source Serif 4',serif;font-size:1.4rem;font-weight:600;color:var(--navy);margin:0 0 .5rem}
.bp-state-card p{color:var(--text-secondary);margin:0 0 1rem;line-height:1.6}
.bp-spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--border-light);border-top-color:var(--teal);animation:bpSpin .8s linear infinite;margin:0 auto 1rem}
@keyframes bpSpin{to{transform:rotate(360deg)}}

/* ── PRINT (Save-as-PDF) ────────────────────────────────────────── */
@media print{
  body{background:#fff !important}
  .nav,footer,.bp-sticky-cta,.bp-contact-card,.bp-progress,.bp-form,.bp-form-meta{display:none !important}
  .bp-stage{padding:0 !important;max-width:none !important}
  .bp-summary{break-inside:avoid;background:#0a1628 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .bp-card{break-inside:avoid;page-break-inside:avoid;border:1px solid #d9d9d9 !important;box-shadow:none !important;margin-bottom:.75rem}
  .bp-card-copy{background:#f7fafc !important;color:#0a1628 !important;border:1px solid #e2e8f0 !important}
  .bp-card-copy strong{color:#0a1628 !important}
  .bp-cards{grid-template-columns:repeat(2,1fr) !important;gap:.75rem !important}
  .bp-calc{break-inside:avoid}
}
