/* ============================================================
   BYOP — shared core for the editorial LP redesigns
   Brand tokens, nav, lead form, reviews, FAQ, footer, sticky CTA
   and the photo-placeholder system. Lifted from byop-v5b.css so
   fonts / colors / form behaviour stay 1:1 with the live site.
   ============================================================ */

:root{
  --ink:#000000;
  --ink-soft:#1C1C1C;
  --ink-soft2:#2B2B2B;
  --ink-deep:#0C0C0C;
  --paper:#FFFFFF;
  --cream:#F6F3EC;
  --cream2:#EFEADF;
  --yellow:#FCCE08;
  --yellow-press:#EFBE00;
  --gold-text:#7A5C00;
  --mute:#5E5A57;
  --faint:#7C7772;
  --mute-dark:#CFCFCF;
  --faint-dark:#A6A6A6;
  --line:#E4E0D7;
  --line-dark:#3D3D3D;
  --ok-bg:#E7F4EA; --ok-fg:#1E6B33; --ok-line:#BBDFC4;
  --bad-bg:#FBEAEA; --bad-fg:#A6271E; --bad-line:#EFC4C0;
  --radius:8px; --radius-lg:14px;
  --gutter:22px;
  --shadow:0 10px 30px rgba(20,18,16,.10);
  --shadow-lg:0 22px 50px rgba(20,18,16,.18);
  --disp:'Barlow Condensed','Barlow',sans-serif;
  --body:'Barlow',sans-serif;
  --mono:'Barlow',ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);font-size:1.04rem;line-height:1.65;color:var(--ink);background:var(--paper);font-weight:400;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1em;text-wrap:pretty}
ul,ol{margin:0;padding:0;list-style:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
input,select,textarea{font:inherit}
strong{font-weight:700}
::selection{background:var(--yellow);color:var(--ink)}
:focus-visible{outline:3px solid var(--yellow);outline-offset:2px;border-radius:2px}

h1,h2,h3,h4,h5{margin:0 0 .5em;line-height:1.04}
h1,h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.005em;text-wrap:balance}
h1{font-size:clamp(2.9rem,7vw,5.6rem);line-height:.92}
h2{font-size:clamp(2.1rem,4.4vw,3.4rem);line-height:.98}
h3{font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.accent{color:var(--yellow)}
.u-disp{font-family:var(--disp);font-weight:700;text-transform:uppercase}

.container{max-width:1200px;margin:0 auto;padding:0 var(--gutter)}
.narrow{max-width:820px;margin:0 auto;padding:0 var(--gutter)}

/* kicker tape */
.kicker{display:inline-block;font-family:var(--disp);font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;font-size:.86rem;color:var(--ink);background:var(--yellow);
  padding:6px 13px;margin-bottom:18px}
.kicker.on-dark{color:var(--ink)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  font-size:1.02rem;line-height:1;padding:16px 26px;border-radius:var(--radius);
  border:2px solid transparent;transition:transform .15s ease,background-color .15s ease,color .15s ease,border-color .15s ease,box-shadow .15s ease;
  cursor:pointer;text-align:center;white-space:nowrap}
.btn:not(.btn-no-arrow)::after{content:"\2192";font-weight:700;transition:transform .15s ease}
.btn:not(.btn-no-arrow):hover::after{transform:translateX(4px)}
.btn-primary{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.btn-primary:hover{background:var(--yellow-press);border-color:var(--yellow-press);transform:translateY(-2px);box-shadow:0 8px 18px rgba(20,18,16,.22)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{border-color:var(--yellow);color:var(--yellow);transform:translateY(-2px)}
.btn-outline-dark{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline-dark:hover{background:var(--ink);color:var(--yellow);transform:translateY(-2px)}
.btn-lg{padding:20px 34px;font-size:1.18rem}
.btn-block{width:100%}

/* ---------- Top notice ---------- */
.rebate-notice{background:var(--yellow);color:var(--ink);padding:11px var(--gutter);text-align:center;font-size:.95rem;font-weight:600;line-height:1.45}
.rebate-notice strong{font-weight:800}

/* ---------- Slim nav ---------- */
.lp-nav{background:var(--ink);padding:13px 0;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line-dark)}
.lp-nav-inner{max-width:1200px;margin:0 auto;padding:0 var(--gutter);display:flex;justify-content:space-between;align-items:center;gap:14px}
.lp-nav .brand{display:inline-flex;align-items:center;flex-shrink:0}
.lp-nav .brand img{height:38px;width:auto}
.lp-nav-brands{display:flex;align-items:center;gap:16px;flex:1;min-width:0}
.lp-nav-identity{display:flex;align-items:center;padding-left:16px;border-left:1px solid var(--line-dark);flex-shrink:0;font-family:var(--disp);font-weight:700;font-size:.84rem;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);line-height:1.25}
.lp-nav-cta{display:flex;align-items:center;gap:14px;flex-shrink:0}
.lp-nav-cta .btn{padding:12px 18px;font-size:.95rem}
.lp-nav-phone{font-family:var(--disp);font-weight:700;font-size:1.02rem;letter-spacing:.03em;color:#fff;white-space:nowrap;transition:color .15s ease}
.lp-nav-phone:hover{color:var(--yellow)}
/* fallback wordmark when logo img missing */
.brand-wordmark{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:1.5rem;color:#fff;line-height:1}
.brand-wordmark .b{color:var(--yellow)}
@media(max-width:720px){
  .lp-nav-identity{padding-left:10px;font-size:.68rem;letter-spacing:.1em}
  .lp-nav-cta{gap:8px}
  .lp-nav-phone{font-size:.9rem}
  .lp-nav-cta .btn{padding:10px 13px;font-size:.85rem}
}
@media(max-width:560px){.lp-nav-identity{display:none}}

/* ============================================================
   LEAD FORM — the white quote sheet (verbatim behaviour)
   ============================================================ */
.lockin-form{background:var(--paper);border-radius:var(--radius-lg);padding:30px 30px 26px;display:flex;flex-direction:column;color:var(--ink);box-shadow:0 30px 70px rgba(0,0,0,.42);border-top:8px solid var(--yellow)}
.lockin-form-head{margin-bottom:18px}
.lockin-form-head h2{font-size:1.7rem;color:var(--ink);margin:0 0 8px;line-height:1}
.lockin-form-head p{font-size:.95rem;color:var(--mute);line-height:1.55;margin:0}
.lockin-form-head p strong{color:var(--ink);font-weight:700}
.lockin-form .form-row{margin-bottom:14px}
.lockin-form .form-row.split{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:601px){.lockin-form .form-row.split{grid-template-columns:1fr 1fr}}
.lockin-form .form-row.split>div{margin:0}
.lockin-form label{display:block;font-family:var(--disp);font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:6px}
.lockin-form input[type="text"],
.lockin-form input[type="tel"],
.lockin-form input[type="email"],
.lockin-form textarea{width:100%;padding:13px 14px;background:var(--paper);border:2px solid var(--line);color:var(--ink);border-radius:var(--radius);font-size:1rem;transition:border-color .15s ease}
.lockin-form textarea{min-height:62px;resize:vertical;line-height:1.45}
.lockin-form input::placeholder,.lockin-form textarea::placeholder{color:var(--faint)}
.lockin-form input:focus,.lockin-form textarea:focus{outline:none;border-color:var(--ink)}
.lockin-form input:focus-visible,.lockin-form textarea:focus-visible{outline:3px solid var(--yellow);outline-offset:1px}
.lockin-form button[type="submit"]{width:100%;justify-content:center;padding:18px 24px;font-size:1.18rem}
.lockin-form-message{display:none;padding:14px 18px;border-radius:var(--radius);margin-bottom:14px;font-size:.95rem;font-weight:600}
.lockin-form-message--success{background:var(--ok-bg);color:var(--ok-fg);border:1px solid var(--ok-line)}
.lockin-form-message--error{background:var(--bad-bg);color:var(--bad-fg);border:1px solid var(--bad-line)}

.form-field-label{display:block;font-family:var(--disp);font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin:0 0 8px}
.step-choices{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.step-card{display:flex;align-items:center;padding:13px 15px;background:var(--cream);border:2px solid var(--line);border-radius:var(--radius);cursor:pointer;transition:border-color .15s ease,background-color .15s ease;position:relative;margin:0}
.step-card:hover{border-color:var(--ink)}
.step-card input[type="radio"]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.step-card-text{color:var(--ink);font-size:.93rem;font-weight:600;line-height:1.25;flex:1}
.step-card:has(input:checked){border-color:var(--ink);background:var(--yellow)}
.step-card:has(input:focus-visible){outline:3px solid var(--ink);outline-offset:2px}
.consent-block{margin:16px 0;padding:14px 16px;background:var(--cream);border:1px solid var(--line);border-radius:var(--radius)}
.consent-lede{font-size:.88rem;color:var(--ink);margin:0 0 12px;line-height:1.5}
.consent-lede em{color:var(--gold-text);font-style:normal;font-weight:700}
.consent-row{display:flex !important;align-items:flex-start;gap:10px;cursor:pointer;margin:0;text-transform:none;letter-spacing:0}
.consent-row input[type="checkbox"]{margin:3px 0 0;accent-color:var(--ink);cursor:pointer;width:16px;height:16px;flex-shrink:0}
.consent-row span{font-family:var(--body);font-size:.8rem;font-weight:400;color:var(--mute);line-height:1.5;text-transform:none;letter-spacing:0}
.consent-row span a{color:var(--gold-text);text-decoration:underline}
.ohnohoney{position:absolute;left:-9999px}
@media(max-width:600px){
  .step-choices{grid-template-columns:1fr}
  .lockin-form-head h2{font-size:1.5rem}
}

/* address autocomplete */
.addr-ac{position:relative}
.addr-ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:40;margin:0;padding:6px 0;list-style:none;background:var(--paper);border:2px solid var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-height:266px;overflow-y:auto}
.addr-ac-list[hidden]{display:none}
.addr-ac-item{display:flex;gap:10px;align-items:flex-start;padding:10px 14px;cursor:pointer;line-height:1.35}
.addr-ac-item[aria-selected="true"],.addr-ac-item:hover{background:var(--cream)}
.addr-ac-pin{flex:0 0 auto;width:16px;height:16px;margin-top:2px;color:var(--gold-text)}
.addr-ac-txt{min-width:0}
.addr-ac-main{display:block;font-weight:600;color:var(--ink);font-size:.96rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.addr-ac-sub{display:block;color:var(--mute);font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.addr-ac-credit{display:flex;justify-content:flex-end;align-items:center;padding:7px 14px 2px;margin-top:4px;border-top:1px solid var(--line);font-size:.72rem;color:var(--faint);cursor:default}

/* ============================================================
   REVIEWS — marquee ribbon + featured pull-quote
   ============================================================ */
.proof-badge{display:inline-flex;align-items:center;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:11px 22px}
.proof-badge.on-dark{background:var(--ink-soft);border-color:var(--line-dark)}
.proof-google-logo{width:28px;height:28px;flex-shrink:0}
.proof-rating-block{display:flex;align-items:baseline;gap:8px}
.proof-rating-num{font-family:var(--disp);font-weight:700;font-size:1.5rem;line-height:1;color:inherit}
.proof-rating-stars{color:var(--gold-text);letter-spacing:.1em}
.proof-badge.on-dark .proof-rating-stars{color:var(--yellow)}
.proof-rating-label{font-weight:600;color:var(--mute);font-size:.95rem}
.proof-badge.on-dark .proof-rating-label{color:var(--mute-dark)}
.proof-badge.on-dark .proof-rating-num{color:#fff}

.proof-ribbon{overflow:hidden;padding:6px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.proof-track{display:flex;gap:18px;width:max-content;animation:byop-marquee 80s linear infinite;padding:0 9px}
.proof-ribbon:hover .proof-track{animation-play-state:paused}
@keyframes byop-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.review-card{flex:0 0 340px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px 24px 20px;display:flex;flex-direction:column}
.review-card.on-dark{background:var(--ink-soft2);border-color:var(--line-dark)}
.review-stars{color:var(--gold-text);letter-spacing:.14em;margin-bottom:12px;font-size:.95rem}
.review-card.on-dark .review-stars{color:var(--yellow)}
.review-text{font-size:.96rem;line-height:1.6;color:var(--ink);margin:0 0 16px;flex:1}
.review-card.on-dark .review-text{color:#EDEAE5}
.review-meta{display:flex;justify-content:space-between;align-items:baseline;gap:10px;border-top:2px solid var(--yellow);padding-top:12px}
.review-name{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.95rem}
.review-card.on-dark .review-name{color:#fff}
.review-date{font-size:.82rem;color:var(--faint);font-weight:600}

.featured-review{max-width:880px;margin:0 auto;border-left:8px solid var(--yellow);padding:14px 0 14px 34px}
.featured-review .fr-stars{color:var(--gold-text);font-size:1.05rem;letter-spacing:.12em;margin-bottom:16px}
.featured-review blockquote{margin:0 0 18px;font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.2;font-family:var(--disp);font-weight:700;letter-spacing:-.005em}
.featured-review .fr-attr{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--mute)}
.featured-review .fr-attr strong{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:1rem;color:inherit}

.proof-link{display:inline-flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.07em;font-size:1rem;color:var(--ink);border:2px solid currentColor;border-radius:var(--radius);padding:13px 22px;transition:background-color .15s ease,color .15s ease}
.proof-link svg{width:18px;height:18px}
.proof-link:hover{background:var(--ink);color:var(--yellow)}

/* ============================================================
   FAQ (compact)
   ============================================================ */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:2px solid var(--line)}
.faq-item:first-child{border-top:2px solid var(--line)}
.faq-question{width:100%;padding:22px 0;text-align:left;font-size:1.1rem;font-weight:700;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-question::after{content:'+';font-family:var(--disp);font-size:1.8rem;font-weight:600;color:var(--gold-text);flex-shrink:0;transition:transform .2s ease;line-height:1}
.faq-item.open{border-bottom-color:var(--yellow)}
.faq-item.open .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-answer{max-height:900px}
.faq-answer p{padding:0 0 22px;color:var(--mute);font-size:1rem;line-height:1.65;margin:0}
.faq-answer p strong{color:var(--ink)}

/* ============================================================
   FOOTER + sticky mobile CTA
   ============================================================ */
.lp-footer{background:var(--ink-deep);padding:44px 0 34px;color:var(--mute-dark);font-size:.86rem;text-align:center;border-top:6px solid var(--yellow)}
.lp-footer a{color:var(--mute-dark);border-bottom:1px dotted var(--line-dark)}
.lp-footer a:hover{color:var(--yellow);border-bottom-color:var(--yellow)}
.lp-footer-meta{margin-top:14px;font-size:.8rem;color:var(--faint-dark);line-height:1.6}

.sticky-mobile-cta{position:fixed;bottom:0;left:0;right:0;background:var(--ink);border-top:4px solid var(--yellow);padding:12px var(--gutter);display:none;align-items:center;gap:12px;z-index:60;transform:translateY(100%);transition:transform .3s ease}
.sticky-mobile-cta.visible{transform:translateY(0)}
.sticky-mobile-cta .sticky-promise{flex:1;min-width:0;color:#fff;font-size:.84rem;line-height:1.3;font-weight:600}
.sticky-mobile-cta .btn{padding:12px 16px;font-size:.92rem}
.sticky-text-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 14px;border-radius:var(--radius);flex-shrink:0;border:2px solid var(--line-dark);background:var(--ink-soft2);color:#fff;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.92rem}
.sticky-text-btn:hover{border-color:var(--yellow);color:var(--yellow)}
@media(max-width:768px){
  .sticky-mobile-cta{display:flex}
  body:has(.sticky-mobile-cta){padding-bottom:76px}
}

/* ============================================================
   PHOTO PLACEHOLDER SYSTEM
   .photo carries a real --img (set inline). When --img is the
   placeholder gradient, the .photo-tag caption tells the dev
   exactly what to drop in and at which path. Swap --img + delete
   the tag to go live.
   ============================================================ */
.photo{position:relative;background-color:var(--ink-soft);background-size:cover;background-position:center;background-image:var(--img,none);filter:saturate(.92) contrast(1.04)}
/* placeholder blocks shouldn't be graded */
.photo--ph{filter:none}
.photo--ph{background-image:
  repeating-linear-gradient(135deg,rgba(252,206,8,.05) 0 2px,transparent 2px 11px),
  linear-gradient(160deg,#23211e,#141312 70%)}
.photo-tag{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;
  max-width:84%;pointer-events:none}
.photo-tag .pt-ico{width:34px;height:34px;color:var(--yellow);opacity:.9}
.photo-tag .pt-label{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--yellow)}
.photo-tag .pt-desc{font-size:.92rem;line-height:1.45;color:#E7E3DA;max-width:34ch;font-weight:500}
.photo-tag .pt-path{font-family:var(--mono);font-size:.72rem;letter-spacing:.02em;color:var(--faint-dark);background:rgba(0,0,0,.4);padding:3px 9px;border-radius:4px;border:1px solid var(--line-dark)}
/* inline placeholder chip used on light blocks */
.ph-note{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:var(--gold-text);background:var(--cream);border:1px dashed #CDB24A;border-radius:6px;padding:5px 10px}

/* ============================================================
   Reduced motion + print
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .proof-ribbon{overflow-x:auto;-webkit-mask-image:none;mask-image:none}
  .proof-track{animation:none;width:auto}
}
@media print{
  .lp-nav,.sticky-mobile-cta{display:none}
  body{background:#fff;color:#000}
}
