/* 2CT Sales Co. — Lead Magnet page styling
 * Premium layout for /playbook/downloads/<slug>/ pages.
 */
.lm-shell { background:#e8e6e1; min-height:100vh; }
.lm-hero { background:var(--navy,#0B1426); color:var(--bone,#F5F3EE); padding:80px 48px 140px; position:relative; overflow:hidden; }
.lm-hero::before { content:""; position:absolute; right:-120px; top:-120px; width:520px; height:520px; background:radial-gradient(circle at center, rgba(200,16,46,.18) 0%, rgba(200,16,46,0) 60%); pointer-events:none; }
.lm-hero .crumb { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(245,243,238,.55); margin-bottom:14px; position:relative; }
.lm-hero .crumb a { color:rgba(245,243,238,.85); border-bottom:0; }
.lm-hero .kicker { display:inline-block; padding:6px 12px; background:rgba(200,16,46,.18); color:#FF6B7E; font-size:11px; letter-spacing:.22em; text-transform:uppercase; font-weight:700; border-radius:2px; margin-bottom:18px; position:relative; }
.lm-hero h1 { font-family:'Bebas Neue',sans-serif; font-size:68px; line-height:.95; letter-spacing:.01em; color:var(--bone,#F5F3EE); margin:0 0 18px; max-width:880px; position:relative; }
.lm-hero .strap { font-size:19px; line-height:1.5; color:rgba(245,243,238,.78); max-width:680px; position:relative; }
.lm-hero .meta { display:flex; flex-wrap:wrap; gap:18px; margin-top:28px; font-size:13px; color:rgba(245,243,238,.6); position:relative; }
.lm-hero .meta span { display:flex; align-items:center; gap:8px; }
.lm-hero .meta b { color:var(--bone,#F5F3EE); font-weight:700; }

.lm-grid { max-width:1180px; margin:-80px auto 0; padding:0 32px; display:grid; grid-template-columns:minmax(0,1fr) 360px; gap:40px; position:relative; z-index:2; align-items:start; }
.lm-main { background:white; padding:48px 56px; border-radius:8px; box-shadow:0 30px 80px rgba(11,20,38,.10); }

.lm-side { position:sticky; top:24px; }
.lm-form-card { background:var(--navy,#0B1426); color:var(--bone,#F5F3EE); padding:30px; border-radius:8px; border-left:4px solid var(--red,#C8102E); box-shadow:0 30px 80px rgba(11,20,38,.20); }
.lm-form-card .pre { font-size:11px; letter-spacing:.22em; color:var(--red,#C8102E); font-weight:700; text-transform:uppercase; margin-bottom:10px; }
.lm-form-card h3 { font-family:'Bebas Neue',sans-serif; font-size:30px; letter-spacing:.02em; line-height:1; margin:0 0 12px; color:var(--bone,#F5F3EE); }
.lm-form-card p.sub { margin:0 0 18px; font-size:14px; line-height:1.5; color:rgba(245,243,238,.78); }
.lm-form-card input[type=email] { width:100%; padding:13px 14px; background:rgba(245,243,238,.07); color:#F5F3EE; border:1px solid rgba(245,243,238,.18); border-radius:3px; font-size:15px; font-family:Inter,sans-serif; box-sizing:border-box; transition:border-color .15s; outline:none; }
.lm-form-card input[type=email]:focus { border-color:var(--red,#C8102E); background:rgba(245,243,238,.10); }
.lm-form-card input[type=email]::placeholder { color:rgba(245,243,238,.4); }
.lm-form-card button { width:100%; margin-top:10px; padding:14px 18px; background:var(--red,#C8102E); color:white; font-weight:700; font-size:13px; letter-spacing:.16em; text-transform:uppercase; border:none; border-radius:2px; cursor:pointer; font-family:Inter,sans-serif; transition:transform .12s, background .12s; }
.lm-form-card button:hover { background:#a50d24; }
.lm-form-card button:disabled { opacity:.6; cursor:wait; }
.lm-form-card .footnote { margin-top:14px; font-size:11px; color:rgba(245,243,238,.5); line-height:1.5; }
.lm-form-card [data-pb-error] { display:none; margin-top:10px; padding:10px 12px; background:rgba(255,107,126,.12); border:1px solid rgba(255,107,126,.35); color:#FFB3BB; font-size:13px; border-radius:3px; }
.lm-form-card [data-pb-status] { display:none; }
.lm-form-card [data-pb-success] { padding:16px; background:rgba(200,16,46,.14); border:1px solid rgba(200,16,46,.4); border-radius:3px; color:var(--bone,#F5F3EE); font-size:14px; line-height:1.55; }
.lm-form-card [data-pb-success] a { color:#FFB3BB; font-weight:700; text-decoration:underline; }

.lm-trust { display:flex; gap:12px; margin-top:14px; padding:12px 14px; background:rgba(245,243,238,.04); border-radius:3px; font-size:12px; color:rgba(245,243,238,.65); line-height:1.45; }
.lm-trust .badge { background:var(--red,#C8102E); color:#fff; padding:2px 6px; font-size:10px; letter-spacing:.14em; font-weight:700; border-radius:2px; height:fit-content; }

.lm-intro { font-size:18px; line-height:1.65; color:var(--steel,#3A3F47); margin-bottom:32px; }
.lm-intro strong { color:var(--navy,#0B1426); }

.lm-rules { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line,rgba(11,20,38,.08)); border-radius:6px; overflow:hidden; margin-bottom:36px; }
.lm-rule { padding:22px 22px 24px; background:var(--bone,#F5F3EE); position:relative; border-right:1px solid var(--line,rgba(11,20,38,.08)); }
.lm-rule:last-child { border-right:0; }
.lm-rule .n { font-family:'Bebas Neue',sans-serif; font-size:34px; color:var(--red,#C8102E); line-height:1; margin-bottom:6px; }
.lm-rule h4 { font-family:Inter,sans-serif; font-weight:700; font-size:15px; color:var(--navy,#0B1426); margin:0 0 6px; }
.lm-rule p { font-size:13.5px; color:var(--steel,#3A3F47); line-height:1.55; margin:0; }

.lm-section-head { display:flex; align-items:baseline; gap:14px; margin:18px 0 22px; }
.lm-section-head .small { font-size:11px; letter-spacing:.22em; color:var(--red,#C8102E); font-weight:700; text-transform:uppercase; }
.lm-section-head h2 { font-family:'Bebas Neue',sans-serif; font-size:38px; letter-spacing:.02em; color:var(--navy,#0B1426); margin:0; line-height:1; }

.lm-card { border:1px solid var(--line,rgba(11,20,38,.08)); border-radius:8px; overflow:hidden; margin-bottom:22px; background:white; transition:box-shadow .2s, transform .2s; }
.lm-card:hover { box-shadow:0 12px 32px rgba(11,20,38,.06); }
.lm-card-head { display:flex; gap:18px; align-items:flex-start; padding:20px 24px; background:var(--bone,#F5F3EE); border-bottom:1px solid var(--line,rgba(11,20,38,.08)); }
.lm-card-num { flex-shrink:0; width:42px; height:42px; background:var(--red,#C8102E); color:white; font-family:'Bebas Neue',sans-serif; font-size:22px; display:flex; align-items:center; justify-content:center; border-radius:3px; line-height:1; padding-top:4px; }
.lm-card-head .h-content { flex:1; min-width:0; }
.lm-card-head .lbl { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--steel,#3A3F47); font-weight:700; margin-bottom:2px; }
.lm-card-head h3 { font-family:Inter,sans-serif; font-weight:700; font-size:18px; color:var(--navy,#0B1426); margin:0 0 4px; line-height:1.3; }
.lm-card-head .when { font-size:13px; color:var(--steel,#3A3F47); line-height:1.5; margin:0; }
.lm-card-head .when b { color:var(--navy,#0B1426); }

.lm-card-body { padding:22px 24px; }
.lm-kv { display:flex; gap:10px; margin-bottom:8px; align-items:baseline; }
.lm-kv .k { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--red,#C8102E); font-weight:700; min-width:60px; }
.lm-kv .v { flex:1; font-family:'SF Mono',Menlo,Consolas,monospace; font-size:13.5px; color:var(--navy,#0B1426); background:var(--bone,#F5F3EE); padding:6px 10px; border-radius:3px; }
.lm-card-body pre { margin:10px 0 0; background:var(--navy,#0B1426); color:var(--bone,#F5F3EE); padding:16px 18px; border-radius:4px; font-family:'SF Mono',Menlo,Consolas,monospace; font-size:13px; line-height:1.6; white-space:pre-wrap; word-break:break-word; overflow-x:auto; }
.lm-card-body .answer { background:var(--bone,#F5F3EE); padding:14px 16px; border-left:3px solid var(--red,#C8102E); border-radius:0 3px 3px 0; font-size:15px; line-height:1.6; color:var(--navy,#0B1426); }
.lm-card-foot { padding:14px 24px 20px; background:white; border-top:1px solid var(--line,rgba(11,20,38,.08)); font-size:13.5px; line-height:1.55; color:var(--steel,#3A3F47); }
.lm-card-foot b { color:var(--navy,#0B1426); }

.lm-lda { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line,rgba(11,20,38,.08)); border-radius:6px; overflow:hidden; margin:18px 0 36px; background:white; }
.lm-lda-cell { padding:24px; border-right:1px solid var(--line,rgba(11,20,38,.08)); position:relative; }
.lm-lda-cell:last-child { border-right:0; }
.lm-lda-cell .big { font-family:'Bebas Neue',sans-serif; font-size:64px; color:var(--red,#C8102E); line-height:.9; margin-bottom:4px; }
.lm-lda-cell .step { font-size:10px; letter-spacing:.22em; color:var(--steel,#3A3F47); font-weight:700; text-transform:uppercase; margin-bottom:8px; }
.lm-lda-cell h4 { font-family:Inter,sans-serif; font-weight:700; font-size:16px; color:var(--navy,#0B1426); margin:0 0 8px; }
.lm-lda-cell p { font-size:13.5px; line-height:1.55; color:var(--steel,#3A3F47); margin:0; }

.lm-related { margin-top:46px; padding-top:32px; border-top:1px solid var(--line,rgba(11,20,38,.08)); }
.lm-related h3 { font-family:'Bebas Neue',sans-serif; font-size:26px; letter-spacing:.02em; color:var(--navy,#0B1426); margin:0 0 18px; }
.lm-related-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.lm-related-card { display:block; padding:18px 20px; background:var(--bone,#F5F3EE); border:1px solid var(--line,rgba(11,20,38,.08)); border-radius:6px; color:var(--navy,#0B1426); transition:transform .12s, box-shadow .12s; border-bottom:1px solid var(--line,rgba(11,20,38,.08)); }
.lm-related-card:hover { transform:translateY(-2px); box-shadow:0 10px 24px rgba(11,20,38,.06); border-color:var(--red,#C8102E); }
.lm-related-card .rcat { font-size:10px; letter-spacing:.22em; color:var(--red,#C8102E); font-weight:700; text-transform:uppercase; margin-bottom:6px; }
.lm-related-card h4 { font-family:Inter,sans-serif; font-weight:700; font-size:15px; color:var(--navy,#0B1426); margin:0 0 4px; line-height:1.35; }
.lm-related-card p { font-size:13px; color:var(--steel,#3A3F47); margin:0; line-height:1.5; }

/* Hub page */
.lm-hub-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px,1fr)); gap:22px; margin-top:36px; }
.lm-hub-card { display:flex; flex-direction:column; background:white; border:1px solid var(--line,rgba(11,20,38,.08)); border-radius:8px; padding:28px; transition:transform .15s, box-shadow .15s; color:var(--navy,#0B1426); border-bottom:1px solid var(--line,rgba(11,20,38,.08)); }
.lm-hub-card:hover { transform:translateY(-3px); box-shadow:0 18px 40px rgba(11,20,38,.10); border-color:var(--red,#C8102E); }
.lm-hub-card .cat { font-size:11px; letter-spacing:.22em; color:var(--red,#C8102E); font-weight:700; text-transform:uppercase; margin-bottom:10px; }
.lm-hub-card h3 { font-family:'Bebas Neue',sans-serif; font-size:30px; letter-spacing:.02em; color:var(--navy,#0B1426); margin:0 0 10px; line-height:1; }
.lm-hub-card p { font-size:14px; line-height:1.55; color:var(--steel,#3A3F47); margin:0 0 18px; }
.lm-hub-card .meta { font-size:11px; letter-spacing:.14em; color:var(--steel,#3A3F47); text-transform:uppercase; margin-top:auto; padding-top:14px; border-top:1px solid var(--line,rgba(11,20,38,.08)); display:flex; justify-content:space-between; }
.lm-hub-card .meta b { color:var(--red,#C8102E); }

@media (max-width: 980px) {
  .lm-grid { grid-template-columns:1fr; padding:0 20px; margin-top:-60px; }
  .lm-main { padding:32px 24px; }
  .lm-hero { padding:64px 24px 100px; }
  .lm-hero h1 { font-size:48px; }
  .lm-hero .strap { font-size:17px; }
  .lm-side { position:static; }
  .lm-rules { grid-template-columns:1fr; }
  .lm-rule { border-right:0; border-bottom:1px solid var(--line,rgba(11,20,38,.08)); }
  .lm-rule:last-child { border-bottom:0; }
  .lm-lda { grid-template-columns:1fr; }
  .lm-lda-cell { border-right:0; border-bottom:1px solid var(--line,rgba(11,20,38,.08)); }
  .lm-lda-cell:last-child { border-bottom:0; }
  .lm-related-grid { grid-template-columns:1fr; }
  .lm-card-head { flex-direction:column; gap:10px; }
  .lm-card-num { width:36px; height:36px; font-size:18px; }
}
@media (max-width: 600px) {
  .lm-hero h1 { font-size:40px; }
  .lm-section-head { flex-direction:column; gap:6px; align-items:flex-start; }
  .lm-section-head h2 { font-size:30px; }
  .lm-kv { flex-direction:column; gap:4px; }
  .lm-kv .k { min-width:0; }
}
