/* ==========================================================================
   CTBeacons — shared styles
   ========================================================================== */

:root{
  --lime:#C7FB3D;
  --lime-deep:#A8D827;
  --orange:#FF5A1F;
  --orange-deep:#E84714;
  --ink:#0B0B0B;
  --ink-2:#1A1A1A;
  --muted:#6E6E6E;
  --muted-2:#8C8C8C;
  --white:#FFFFFF;
  --paper:#FAFAF8;
  --line:#EAEAE6;
  --line-strong:#D9D9D4;

  --font-sans:'Lato', system-ui, -apple-system, sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, monospace;

  --container:1240px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:17px; line-height:1.55;
  color:var(--ink);
  background:var(--white);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}
.skip-link{
  position:absolute; top:-100%; left:16px;
  padding:12px 20px; background:var(--ink); color:var(--white);
  border-radius:0 0 8px 8px; font-size:14px; font-weight:600;
  z-index:100; transition:top .2s ease;
}
.skip-link:focus{top:0}
.container{max-width:var(--container); margin:0 auto; padding:0 32px}

h1,h2,h3,h4{
  font-family:var(--font-sans); font-weight:900;
  letter-spacing:-0.025em; line-height:1.05;
  margin:0; color:var(--ink); text-wrap:balance;
}
h1{font-size:clamp(48px, 7vw, 96px); letter-spacing:-0.035em; line-height:1}
h2{font-size:clamp(36px, 4.8vw, 64px); letter-spacing:-0.03em}
h3{font-size:24px; letter-spacing:-0.015em; font-weight:700}
p{margin:0; text-wrap:pretty}

.eyebrow{
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--ink); font-weight:500;
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; width:8px; height:8px; border-radius:50%;
  background:var(--lime);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:600; font-size:15px;
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap; cursor:pointer;
}
.btn .arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(3px)}
.btn-lime{background:var(--lime); color:var(--ink)}
.btn-lime:hover{background:#D5FF55; transform:translateY(-1px)}
.btn-ink{background:var(--ink); color:var(--white)}
.btn-ink:hover{background:#1A1A1A; transform:translateY(-1px)}
.btn-orange{background:var(--orange); color:var(--white)}
.btn-orange:hover{background:#FF6E3A; transform:translateY(-1px)}
.btn-ghost{background:transparent; color:var(--ink); border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--white)}
.btn-ghost-light{background:transparent; color:var(--white); border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost-light:hover{border-color:var(--white); transform:translateY(-1px)}
.btn-lg{padding:18px 30px; font-size:16px}
.btn-sm{padding:10px 18px; font-size:14px}

/* ---------- Logo ---------- */
.logo{display:inline-flex; align-items:center; gap:12px}
.logo-mark{width:32px; height:40px; flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center}
.logo-name{
  font-family:var(--font-sans);
  letter-spacing:-0.02em; font-weight:500; font-size:19px;
  color:var(--ink);
}
.logo-name b{font-weight:700}
.logo-name .accent{color:var(--orange)}

/* ---------- Nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:18px 0;
  transition:background .3s ease, padding .3s ease, backdrop-filter .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom-color:var(--line);
  padding:12px 0;
}
.nav-inner{display:flex; align-items:center; justify-content:space-between; gap:24px}
.nav-links{display:flex; align-items:center; gap:2px}
.nav-links a{
  position:relative; padding:9px 14px;
  font-size:14.5px; font-weight:500; color:var(--ink-2);
  border-radius:999px;
  transition:background .25s ease, color .25s ease;
}
.nav-links a:hover{background:rgba(11,11,11,.05)}
.nav-links a.active{background:var(--ink); color:var(--white)}
.nav-cta{display:flex; align-items:center; gap:10px}
.nav .btn-lime{padding:9px 16px; font-size:13.5px; font-weight:600}

.menu-toggle{
  display:none; width:42px; height:42px; border-radius:999px;
  background:transparent; border:1.5px solid var(--ink);
  align-items:center; justify-content:center;
  cursor:pointer; z-index:50; position:relative;
  transition:border-color .3s ease, background .3s ease;
}
.menu-toggle span, .menu-toggle span::before, .menu-toggle span::after{
  display:block; width:18px; height:1.5px; background:var(--ink);
  transition:all .2s;
}
.menu-toggle span{position:relative}
.menu-toggle span::before{content:""; position:absolute; top:-5px; left:0}
.menu-toggle span::after{content:""; position:absolute; top:5px; left:0}
.menu-toggle.open span{background:transparent}
.menu-toggle.open span::before{top:0; transform:rotate(45deg); background:var(--ink);}
.menu-toggle.open span::after{top:0; transform:rotate(-45deg); background:var(--ink);}

.mobile-menu{
  position:fixed; top:0; left:0; width:100vw; height:100vh; height:100dvh;
  background:var(--paper); z-index:40;
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:20px;
  transform:translateY(-100%); transition:transform .4s cubic-bezier(0.77, 0, 0.175, 1), opacity .4s, visibility .4s;
  opacity:0; visibility:hidden;
}
.mobile-menu.open{transform:none; opacity:1; visibility:visible;}
.mobile-menu a{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 4px; font-size:22px; font-weight:600;
  letter-spacing:-0.025em;
  border-bottom:1px solid rgba(11,11,11,.08);
  color:var(--ink);
}
.mobile-menu a:last-of-type{border-bottom:none}
.mobile-menu a.cta{
  margin-top:24px;
  background:var(--lime); color:var(--ink);
  border-radius:999px; padding:18px 24px;
  font-size:18px; justify-content:center;
  border:none;
}

/* ---------- Page intro (per page hero) ---------- */
.page-intro{
  padding:170px 0 60px;
  border-bottom:1px solid var(--line);
}
.page-intro .container{max-width:980px}
.page-intro .eyebrow{margin-bottom:24px}
.page-intro h1{
  font-size:clamp(48px, 6vw, 88px);
  letter-spacing:-0.04em; line-height:0.98;
}
.page-intro .sub{
  font-size:22px; color:var(--muted);
  margin-top:24px; max-width:680px;
}

/* ---------- Reveals ---------- */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}

/* ---------- FAB ---------- */
.fab{
  position:fixed; right:24px; bottom:24px; z-index:60;
  display:inline-flex; align-items:center; gap:0;
  padding:18px 28px;
  border-radius:999px;
  background:var(--lime);
  color:var(--ink);
  font-weight:900; font-size:15px;
  letter-spacing:-0.005em;
  box-shadow:
    0 18px 40px -14px rgba(199,251,61,.7),
    0 0 0 6px rgba(199,251,61,.18);
  transform:translateY(80px) scale(.92);
  opacity:0;
  transition:transform .5s cubic-bezier(.2,.7,.2,1), opacity .4s ease, background .25s ease, box-shadow .25s ease;
  cursor:pointer;
}
.fab.shown{transform:none; opacity:1}
.fab:hover{background:#D5FF55; box-shadow:0 22px 48px -14px rgba(199,251,61,.85), 0 0 0 8px rgba(199,251,61,.22)}

/* ---------- Background beacon ---------- */
.bg-beacon{
  position:fixed;
  right:-15vw; top:50%;
  transform:translateY(-50%);
  width:76vw; max-width:760px;
  opacity:.15;
  pointer-events:none;
  z-index:-1;
}
.bg-beacon path {
  stroke-width: 4 !important;
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .reveal{opacity:1; transform:none}
}

/* ---------- Footer ---------- */
footer{
  background:var(--ink); color:rgba(255,255,255,.65);
  padding:64px 0 32px;
  margin-top:0;
}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand .logo .logo-name{color:var(--white)}
.footer-brand p{
  color:rgba(255,255,255,.6); font-size:15px;
  margin-top:18px; max-width:280px;
}
.footer-col h4{
  color:var(--white);
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase;
  font-weight:500;
  margin-bottom:20px;
}
.footer-col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px}
.footer-col a{color:rgba(255,255,255,.65); font-size:15px; transition:color .2s ease}
.footer-col a:hover{color:var(--lime)}
.footer-meta{
  margin-top:24px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.12em; text-transform:uppercase;
  color:rgba(255,255,255,.4);
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .container{padding:0 24px}
  .nav-links{display:none}
  .menu-toggle{display:flex}
  .page-intro{padding:130px 0 40px}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px}
  .footer-meta{flex-direction:column; align-items:flex-start; gap:10px}
  .fab{right:16px; bottom:16px; padding:14px 20px; font-size:14px}
  .nav-cta .btn-lime{display:none}
  .bg-beacon{right:-50vw; width:100vw; max-width:500px; opacity:.05}
}
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr}
}

/* Styles from about.html */

.studio{padding:80px 0 100px}
.studio-grid{
  display:grid; grid-template-columns:1.1fr .9fr;
  gap:80px; align-items:flex-start;
}
.studio-body p{font-size:19px; color:var(--ink-2); line-height:1.55; margin-bottom:20px; max-width:560px}
.studio-body p.lead{font-size:28px; color:var(--ink); line-height:1.3; letter-spacing:-0.015em; font-weight:500; margin-bottom:28px}
.studio-card{
  background:var(--paper); border:1px solid var(--line);
  border-radius:24px; padding:36px;
}
.studio-card h3{font-size:20px; letter-spacing:-0.02em; margin-bottom:20px}
.avail-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px}
.avail-list li{
  display:flex; align-items:flex-start; gap:12px;
  font-size:15.5px; color:var(--ink-2); line-height:1.45;
}
.avail-list li::before{
  content:""; flex:0 0 auto;
  width:18px; height:18px; border-radius:50%;
  background:var(--lime); margin-top:2px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 14 14'><path d='M3.5 7.2l2.2 2.2 5-5' stroke='%230B0B0B' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:center;
}
.studio-card .row-meta{
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:18px; margin-top:28px; padding-top:24px;
  border-top:1px solid var(--line);
}
.studio-card .row-meta span{display:block; font-family:var(--font-mono); font-size:10px; color:var(--muted); letter-spacing:0.14em; text-transform:uppercase; margin-bottom:4px}
.studio-card .row-meta b{font-size:14px; color:var(--ink)}

/* People */
.people{
  padding:120px 0;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.people-head{margin-bottom:48px}
.people-head h2{font-size:clamp(36px, 5vw, 60px)}
.people-head h2 .lime{background:var(--lime); padding:0 .12em; border-radius:6px; display:inline-block; transform:rotate(-1deg)}
.people-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
.person{
  background:var(--white); border:1px solid var(--line);
  border-radius:28px; padding:40px;
  display:flex; flex-direction:column;
}
.person-head{display:flex; align-items:center; gap:20px; margin-bottom:24px}
.person-avatar{
  width:72px; height:72px; border-radius:50%;
  display:grid; place-items:center;
  font-weight:700; font-size:28px;
}
.person.dan .person-avatar{background:var(--lime); color:var(--ink)}
.person.james .person-avatar{background:var(--orange); color:var(--white)}
.person-name b{display:block; font-size:24px; letter-spacing:-0.02em}
.person-name span{font-family:var(--font-mono); font-size:12px; color:var(--muted); letter-spacing:0.1em; text-transform:uppercase; margin-top:4px; display:block}
.person p{color:var(--ink-2); font-size:16px; line-height:1.55; margin-bottom:14px}
.person .skills{
  display:flex; flex-wrap:wrap; gap:6px;
  margin-top:auto; padding-top:24px;
  border-top:1px solid var(--line);
}
.person .skills span{
  font-family:var(--font-mono); font-size:11px;
  padding:5px 11px; border-radius:999px;
  background:var(--paper); color:var(--ink-2);
  letter-spacing:0.08em; text-transform:uppercase;
}

/* Local */
.local{padding:120px 0}
.local-inner{max-width:640px}
.local h2{font-size:clamp(36px, 5vw, 56px)}
.local p{font-size:18px; color:var(--ink-2); line-height:1.55; margin-top:20px; max-width:480px}
.local-img{
  aspect-ratio:4/5;
  background:linear-gradient(90deg, var(--lime) 0%, var(--orange) 100%);
  border-radius:28px;
  position:relative; overflow:hidden;
  display:flex; align-items:flex-end; justify-content:flex-start;
  padding:32px;
}
.local-img .beacon{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-58%);
  z-index:2;
}
.local-img .place{
  position:relative; z-index:2;
  color:var(--white);
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase;
}
.local-img .place b{
  display:block; font-family:var(--font-sans); font-size:24px;
  letter-spacing:-0.02em; text-transform:none; font-weight:600;
  margin-top:6px;
}

@media (max-width:960px){
  .studio-grid, .people-grid, .local-inner{grid-template-columns:1fr; gap:36px}
  .studio{padding:48px 0 60px}
  .people, .local{padding:64px 0}
}

/* Styles from approach.html */

.principles{padding:80px 0 120px}
.principle{
  display:grid; grid-template-columns:.9fr 1.6fr;
  gap:64px; align-items:flex-start;
  padding:64px 0;
  border-top:1px solid var(--line);
}
.principle:last-child{border-bottom:1px solid var(--line)}
.principle-side{position:sticky; top:120px}
.principle-num{
  font-family:var(--font-mono); font-size:12px;
  color:var(--muted); letter-spacing:0.16em;
  text-transform:uppercase; margin-bottom:18px;
  display:block;
}
.principle-icon{
  width:84px; height:84px; border-radius:22px;
  display:grid; place-items:center;
  margin-bottom:24px;
}
.p1 .principle-icon{background:var(--lime); color:var(--ink)}
.p2 .principle-icon{background:var(--orange); color:var(--white)}
.p3 .principle-icon{background:var(--ink); color:var(--lime)}
.principle h2{font-size:40px; letter-spacing:-0.03em; line-height:1.05; margin-bottom:12px}
.principle .tag{font-family:var(--font-mono); font-size:13px; color:var(--muted); letter-spacing:0.08em}
.principle-body p{font-size:19px; color:var(--ink-2); line-height:1.55; margin-bottom:18px; max-width:620px}
.principle-body p.lead{font-size:24px; color:var(--ink); font-weight:500; line-height:1.35; letter-spacing:-0.015em; margin-bottom:28px; max-width:620px}
.principle-body ul{list-style:none; padding:24px 0 0; margin:24px 0 0; display:flex; flex-direction:column; gap:14px; border-top:1px dashed var(--line); max-width:620px}
.principle-body li{display:flex; gap:14px; font-size:16px; color:var(--ink-2); line-height:1.4}
.principle-body li::before{
  content:""; flex:0 0 auto;
  width:8px; height:8px; border-radius:50%;
  background:var(--lime); margin-top:9px;
}
.principle-body li b{color:var(--ink); font-weight:600; margin-right:6px}

.manifesto{
  padding:100px 0;
  background:var(--ink); color:var(--white);
  text-align:center;
}
.manifesto h2{
  color:var(--white);
  font-size:clamp(36px, 5vw, 64px);
  max-width:880px; margin:0 auto;
  letter-spacing:-0.035em; line-height:1.05;
}
.manifesto h2 .lime{background:var(--lime); color:var(--ink); padding:0 .14em; border-radius:8px; display:inline-block; transform:rotate(-1deg)}
.manifesto p{color:rgba(255,255,255,.7); font-size:19px; max-width:620px; margin:24px auto 36px}

@media (max-width:960px){
  .principle{grid-template-columns:1fr; gap:24px; padding:40px 0}
  .principle-side{position:static}
  .principles{padding:40px 0 80px}
}

/* Styles from contact.html */

.contact{padding:80px 0 120px}
.contact-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:80px; align-items:flex-start}
.contact-intro{position:sticky; top:120px}
.contact-intro h2{font-size:clamp(36px, 5vw, 56px); letter-spacing:-0.035em; line-height:1.05}
.contact-intro h2 .lime{background:var(--lime); color:var(--ink); padding:0 .12em; border-radius:8px; display:inline-block; transform:rotate(-1deg)}
.contact-intro .sub{color:var(--muted); font-size:18px; max-width:380px; margin:24px 0 32px; line-height:1.5}
.contact-info{display:flex; flex-direction:column; gap:0}
.contact-info a, .contact-info div.cinfo{
  display:flex; align-items:flex-start; gap:14px;
  padding:20px 0;
  border-top:1px solid var(--line);
  transition:color .2s ease;
}
.contact-info a:hover{color:var(--ink)}
.contact-info .icon{
  width:42px; height:42px; border-radius:12px;
  background:var(--lime); color:var(--ink);
  display:grid; place-items:center; flex:0 0 auto;
}
.contact-info .label{
  display:block; font-family:var(--font-mono); font-size:10px;
  color:var(--muted); letter-spacing:0.14em; text-transform:uppercase;
  margin-bottom:4px;
}
.contact-info .val{font-weight:600; font-size:16px}

/* Form */
.contact-form{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:24px;
  padding:40px;
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px}
.field{display:flex; flex-direction:column; gap:8px; position:relative}
.field.full{grid-column:1/-1}
.field label{
  font-family:var(--font-mono); font-size:10px; color:var(--muted);
  letter-spacing:0.14em; text-transform:uppercase; font-weight:500;
}
.field input, .field select, .field textarea{
  width:100%; padding:14px 16px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:12px; color:var(--ink);
  font-family:var(--font-sans); font-size:15px;
  transition:border-color .2s ease;
  outline:none;
}
.field textarea{resize:vertical; min-height:140px; line-height:1.5}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--ink)}
.field input::placeholder, .field textarea::placeholder{color:var(--muted-2)}
.field.error input, .field.error textarea, .field.error select{border-color:var(--orange); background:rgba(255,90,31,.04)}
.field .err-msg{font-family:var(--font-mono); font-size:11px; color:var(--orange); display:none; margin-top:2px; letter-spacing:0.05em}
.field.error .err-msg{display:block}
.field select{
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%230B0B0B' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:40px;
}
.chip-row{display:flex; flex-wrap:wrap; gap:8px}
.chip{
  padding:9px 16px; border-radius:999px;
  background:var(--white); border:1px solid var(--line);
  color:var(--ink-2); font-size:13.5px; font-weight:500;
  cursor:pointer; transition:all .2s ease;
}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--ink); color:var(--white); border-color:var(--ink)}

.form-foot{display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:24px; flex-wrap:wrap}
.form-foot .note{font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:0.08em}
.submit-btn{
  background:var(--ink); color:var(--white);
  padding:16px 28px; border-radius:999px;
  font-weight:600; font-size:15px;
  display:inline-flex; align-items:center; gap:10px;
  transition:transform .25s ease, background .25s ease;
}
.submit-btn:hover:not(:disabled){background:#1A1A1A; transform:translateY(-1px)}
.submit-btn:disabled{opacity:.6; cursor:wait}

.form-success{display:none; text-align:center; padding:24px 0}
.form-success.shown{display:block; animation:fadeUp .5s ease}
@keyframes fadeUp{from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none}}
.form-success .check{
  width:64px; height:64px; border-radius:50%;
  background:var(--lime); color:var(--ink);
  display:grid; place-items:center; margin:0 auto 16px;
}
.form-success h3{margin-bottom:8px}
.form-success p{color:var(--muted); font-size:15px; max-width:340px; margin:0 auto}

@media (max-width:960px){
  .contact-grid{grid-template-columns:1fr; gap:36px}
  .contact-intro{position:static}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:28px}
  .contact{padding:48px 0 64px}
}

/* Styles from how-we-work.html */

.process{padding:80px 0 140px}
.step{
  display:grid; grid-template-columns:140px 1.1fr .9fr;
  gap:48px; align-items:start;
  padding:48px 0;
  border-top:1px solid var(--line);
  position:relative;
}
.step:last-child{border-bottom:1px solid var(--line)}
.step:hover{background:var(--paper); margin:0 -32px; padding-left:32px; padding-right:32px; border-radius:0}
.step-num{
  font-family:var(--font-mono); font-size:13px;
  color:var(--muted); letter-spacing:0.14em;
  text-transform:uppercase;
  display:flex; flex-direction:column; gap:6px;
}
.step-num b{
  font-family:var(--font-sans); font-size:62px;
  font-weight:600; color:var(--ink);
  letter-spacing:-0.04em; line-height:1;
}
.step-body h2{font-size:36px; letter-spacing:-0.025em; line-height:1.05; margin-bottom:14px}
.step-body p{font-size:17px; color:var(--ink-2); line-height:1.55; max-width:520px}
.step-meta{
  display:flex; flex-direction:column; gap:16px;
  padding-top:8px;
}
.step-meta .row{
  display:flex; gap:14px;
  padding:14px 18px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:14px;
  font-size:14px;
}
.step:hover .step-meta .row{background:var(--white)}
.step-meta .row .lbl{
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:0.14em; text-transform:uppercase;
  color:var(--muted); flex:0 0 auto;
  align-self:center;
}
.step-meta .row .val{font-weight:500; color:var(--ink)}
.step-meta .row .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--lime); margin-top:6px; flex:0 0 auto;
}
.step-meta .row.orange .dot{background:var(--orange)}

.aside{
  padding:100px 0;
  background:var(--ink); color:var(--white);
}
.aside-inner{
  display:grid; grid-template-columns:1fr 1fr; gap:64px;
  align-items:center; max-width:1100px; margin:0 auto;
}
.aside h2{color:var(--white); font-size:clamp(36px, 5vw, 60px)}
.aside h2 .lime{
  background:var(--lime); color:var(--ink);
  padding:0 .14em; border-radius:8px;
  display:inline-block; transform:rotate(-1deg);
}
.aside p{font-size:18px; color:rgba(255,255,255,.7); margin-top:20px; max-width:480px; line-height:1.5}
.aside .stat-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
}
.stat{
  background:#161616;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:28px;
}
.stat b{display:block; font-size:48px; font-weight:600; color:var(--lime); letter-spacing:-0.03em; line-height:1; margin-bottom:10px}
.stat span{font-family:var(--font-mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,.6)}

@media (max-width:960px){
  .step{grid-template-columns:1fr; gap:24px; padding:32px 0}
  .step:hover{margin:0; padding-left:0; padding-right:0; background:transparent}
  .step-num{flex-direction:row; align-items:baseline; gap:16px}
  .step-num b{font-size:48px}
  .aside-inner{grid-template-columns:1fr; gap:36px}
  .process{padding:48px 0 80px}
}

/* Styles from index.html */

/* ---------- Home page only ---------- */
.hero{
  position:relative;
  padding:160px 0 80px;
  text-align:center;
  overflow:hidden;
}
.hero .container{max-width:1100px}
.hero .eyebrow{margin-bottom:32px; justify-content:center; display:inline-flex}
.hero h1{
  font-size:clamp(56px, 9vw, 132px);
  letter-spacing:-0.05em;
  line-height:0.95;
  font-weight:600;
}
.hero h1 .lime{
  background:var(--lime);
  padding:0 .12em;
  border-radius:8px;
  display:inline-block;
  transform:rotate(-1.2deg);
}
.hero-sub{
  font-size:22px; color:var(--muted);
  max-width:680px; margin:36px auto 0;
  line-height:1.4;
}
.hero-actions{
  display:flex; gap:12px; flex-wrap:wrap;
  justify-content:center; margin-top:44px;
}
.hero-actions .btn{padding:16px 28px; font-size:15px}

/* trust strip */
.trust{
  display:flex; justify-content:center; gap:36px;
  flex-wrap:wrap;
  margin-top:60px;
  padding-top:40px;
  border-top:1px solid var(--line);
  font-family:var(--font-mono); font-size:12px;
  color:var(--muted); letter-spacing:0.12em; text-transform:uppercase;
}
.trust span{display:flex; align-items:center; gap:8px}
.trust span::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--lime);
}

/* Value props */
.values{padding:120px 0; border-bottom:1px solid var(--line)}
.values-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:48px;
}
.value{display:flex; flex-direction:column; gap:14px}
.value-num{
  font-family:var(--font-mono); font-size:12px;
  color:var(--muted); letter-spacing:0.16em;
  text-transform:uppercase;
}
.value h3{font-size:30px; letter-spacing:-0.03em; line-height:1.1}
.value p{color:var(--muted); font-size:16px; line-height:1.5}

/* Services preview */
.svc-preview{padding:120px 0; background:var(--paper); border-bottom:1px solid var(--line)}
.svc-head{
  display:grid; grid-template-columns:1fr 1fr; gap:48px;
  align-items:end; margin-bottom:64px;
}
.svc-head .lede{color:var(--muted); font-size:18px; max-width:440px; margin-left:auto}
.svc-cards{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:20px;
}
.svc-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:24px;
  padding:36px 32px 32px;
  display:flex; flex-direction:column;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.svc-card:hover{transform:translateY(-4px); border-color:var(--line-strong); box-shadow:0 20px 40px -20px rgba(11,11,11,.1)}
.svc-card.featured{background:var(--ink); color:var(--white); border-color:var(--ink)}
.svc-card.featured h3{color:var(--white)}
.svc-card.featured .svc-desc{color:rgba(255,255,255,.7)}
.svc-card.featured .svc-tag{background:var(--lime); color:var(--ink)}
.svc-card.featured .svc-price{color:var(--lime)}
.svc-card.featured .svc-cta{background:var(--lime); color:var(--ink)}
.svc-card.featured .svc-feat{color:rgba(255,255,255,.85); border-top-color:rgba(255,255,255,.08)}
.svc-tag{
  align-self:flex-start;
  padding:5px 11px; border-radius:999px;
  background:var(--paper); color:var(--ink);
  font-family:var(--font-mono); font-size:10px; font-weight:500;
  letter-spacing:0.12em; text-transform:uppercase;
  margin-bottom:24px; border:1px solid var(--line);
}
.svc-card.featured .svc-tag{border-color:var(--lime)}
.svc-card h3{font-size:24px; margin-bottom:6px}
.svc-price{
  display:flex; align-items:baseline; gap:6px;
  font-size:44px; font-weight:600; color:var(--ink);
  letter-spacing:-0.03em; margin-top:6px; margin-bottom:18px;
}
.svc-price small{font-family:var(--font-mono); font-size:12px; color:var(--muted); font-weight:400; letter-spacing:0.05em}
.svc-desc{color:var(--muted); font-size:15px; margin-bottom:24px; line-height:1.5}
.svc-feat{
  list-style:none; padding:20px 0 0; margin:0 0 28px;
  display:flex; flex-direction:column; gap:10px;
  border-top:1px solid var(--line);
  font-size:14.5px;
}
.svc-feat li{display:flex; gap:10px; align-items:flex-start}
.svc-feat li::before{
  content:""; width:14px; height:14px; border-radius:50%;
  background:var(--lime); flex:0 0 auto; margin-top:3px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'><path d='M3.5 7.2l2.2 2.2 5-5' stroke='%230B0B0B' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
}
.svc-cta{
  margin-top:auto; align-self:flex-start;
  background:var(--ink); color:var(--white);
  padding:12px 18px; border-radius:999px;
  font-size:14px; font-weight:600;
  display:inline-flex; align-items:center; gap:8px;
  transition:background .25s ease, transform .25s ease;
}
.svc-cta:hover{transform:translateY(-1px)}
.svc-cta .arrow{transition:transform .25s ease}
.svc-cta:hover .arrow{transform:translateX(3px)}

/* Marquee */
.marquee{
  padding:24px 0;
  background:var(--ink); color:var(--white);
  overflow:hidden; position:relative;
}
.marquee-track{
  display:flex; gap:48px;
  white-space:nowrap;
  animation:scroll 32s linear infinite;
  font-size:32px; font-weight:500;
  letter-spacing:-0.025em;
}
.marquee-track .item{display:inline-flex; align-items:center; gap:48px}
.marquee-track .item::after{
  content:""; width:14px; height:14px; border-radius:50%;
  background:var(--lime); flex:0 0 auto;
}
@keyframes scroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* Refer a friend */
.refer{
  padding:140px 0 120px;
  background:var(--white);
}
.refer-card{
  background:var(--lime);
  border-radius:32px;
  padding:80px;
  position:relative; overflow:hidden;
  display:grid; grid-template-columns:1.2fr .8fr;
  gap:64px; align-items:center;
}
.refer-card::before{
  content:""; position:absolute;
  right:-80px; top:-80px;
  width:340px; height:340px; border-radius:50%;
  background:rgba(11,11,11,.05);
}
.refer-card::after{
  content:""; position:absolute;
  right:60px; bottom:-160px;
  width:260px; height:260px; border-radius:50%;
  background:rgba(255,90,31,.18);
}
.refer-copy{position:relative; z-index:2}
.refer-copy .eyebrow{margin-bottom:24px}
.refer-copy .eyebrow::before{background:var(--ink)}
.refer-copy h2{
  font-size:clamp(40px, 5.4vw, 72px);
  letter-spacing:-0.04em; line-height:0.96;
  margin-bottom:20px;
}
.refer-copy h2 .both{
  display:inline-block;
  background:var(--ink); color:var(--lime);
  padding:0 .15em;
  border-radius:8px;
  transform:rotate(-1deg);
}
.refer-copy .sub{
  font-size:19px; color:var(--ink-2);
  margin-bottom:32px; max-width:500px;
  line-height:1.4;
}
.refer-actions{display:flex; gap:12px; flex-wrap:wrap}
.refer-steps{
  position:relative; z-index:2;
  display:flex; flex-direction:column; gap:14px;
}
.refer-step{
  background:var(--white);
  border-radius:18px; padding:20px 22px;
  display:flex; gap:16px; align-items:flex-start;
}
.refer-step .n{
  flex:0 0 auto;
  width:34px; height:34px; border-radius:50%;
  background:var(--ink); color:var(--lime);
  display:grid; place-items:center;
  font-weight:700; font-size:14px;
}
.refer-step b{display:block; font-weight:600; font-size:16px; margin-bottom:4px}
.refer-step p{font-size:14px; color:var(--muted); line-height:1.45}

/* Refer form (collapsed by default) */
.refer-form{
  display:none;
  margin-top:24px;
  background:var(--white);
  border-radius:18px;
  padding:24px;
  box-shadow:0 18px 40px -20px rgba(11,11,11,.15);
}
.refer-form.shown{display:block}
.refer-form .form-row{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px}
.refer-form label{
  display:block; font-family:var(--font-mono);
  font-size:10px; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--muted);
  margin-bottom:6px; font-weight:500;
}
.refer-form input{
  width:100%; padding:12px 14px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:10px;
  font-family:var(--font-sans); font-size:15px;
  color:var(--ink); outline:none;
  transition:border-color .2s ease, background .2s ease;
}
.refer-form input:focus{border-color:var(--ink); background:var(--white)}
.refer-form .row-actions{display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:16px; flex-wrap:wrap}
.refer-form .row-actions .note{font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:0.08em}
.refer-thanks{
  display:none;
  margin-top:18px;
  padding:18px;
  background:var(--white); border-radius:14px;
  border:1px solid var(--line);
  font-size:15px; color:var(--ink);
}
.refer-thanks.shown{display:block}
.refer-thanks b{display:block; margin-bottom:4px}

/* Responsive */
@media (max-width:960px){
  .hero{padding:120px 0 50px}
  .trust{gap:20px}
  .values{padding:80px 0}
  .values-grid{grid-template-columns:1fr; gap:32px}
  .svc-preview{padding:80px 0}
  .svc-head{grid-template-columns:1fr; gap:20px; margin-bottom:40px}
  .svc-head .lede{margin-left:0}
  .svc-cards{grid-template-columns:1fr; gap:14px}
  .refer{padding:80px 0}
  .refer-card{grid-template-columns:1fr; padding:40px 28px; gap:36px}
  .marquee-track{font-size:24px}
}

/* Styles from portfolio.html */

.portfolio { padding: 40px 0 120px; }
.portfolio-grid { display: grid; grid-template-columns: 1fr; gap: 64px; }
.portfolio-card {
  display: block;
  border-radius: 24px;
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--line);
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}
.portfolio-card:hover {
  transform: translateY(-4px);
  border-color: var(--ink);
  box-shadow: 0 12px 32px -12px rgba(0,0,0,.15);
}
.portfolio-img {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--line);
  border-bottom: 1px solid var(--line);
}
.portfolio-img::after {
  content: "CTBeacons";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) rotate(-15deg);
  font-family: var(--font-sans); font-weight: 900; font-size: 8vw;
  color: rgba(255, 255, 255, 0.4); text-shadow: 0 4px 24px rgba(0,0,0,0.5);
  pointer-events: none; z-index: 10; white-space: nowrap;
}
@media (min-width: 960px) {
  .portfolio-img::after { font-size: 4vw; }
}
.portfolio-img img {
  width: 100%;
  height: auto;
  min-height: 100%;
  object-fit: cover;
  object-position: top;
  transition: transform 4s cubic-bezier(0.25, 1, 0.5, 1);
}
.portfolio-card:hover .portfolio-img img {
  transform: translateY(-5%);
}

/* 50005 Carousel */
.portfolio-img.carousel img {
  position: absolute; top: 0; left: 0; width: 100%;
  opacity: 0;
  animation: fadeCycle 12s infinite;
}
.portfolio-img.carousel img:nth-child(1) { position: relative; animation-delay: 0s; opacity: 1; }
.portfolio-img.carousel img:nth-child(2) { animation-delay: 4s; }
.portfolio-img.carousel img:nth-child(3) { animation-delay: 8s; }
@keyframes fadeCycle {
  0%, 25% { opacity: 1; }
  33.33%, 91.66% { opacity: 0; }
  100% { opacity: 1; }
}

/* Lightbox Modal */
.portfolio-lightbox {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
}
.portfolio-lightbox.active { opacity: 1; pointer-events: auto; }
.lightbox-overlay { position: absolute; inset: 0; background: rgba(11, 11, 11, 0.95); }
.lightbox-close {
  position: absolute; top: 24px; right: 24px; z-index: 2;
  background: none; border: none; color: #fff; font-size: 48px;
  cursor: pointer; line-height: 1; padding: 0 10px;
}
.lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
  background: rgba(255,255,255,0.1); border: none; border-radius: 50%;
  color: #fff; width: 56px; height: 56px; font-size: 24px;
  cursor: pointer; transition: background 0.2s;
  display: none;
}
.lightbox-nav:hover { background: rgba(255,255,255,0.2); }
.lightbox-nav.prev { left: 24px; }
.lightbox-nav.next { right: 24px; }
.lightbox-content {
  position: relative; z-index: 1;
  width: 90vw; max-width: 1200px; height: 85vh;
  background: var(--line); border-radius: 12px; overflow: hidden;
}
.lightbox-scroll {
  position: relative;
  width: 100%; height: 100%; overflow-y: auto; overflow-x: hidden;
}
.lightbox-scroll img { width: 100%; height: auto; display: block; }
.lightbox-scroll::after {
  content: "CTBeacons"; position: absolute;
  top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(-15deg);
  font-family: var(--font-sans); font-weight: 900; font-size: 6vw;
  color: rgba(255, 255, 255, 0.4); text-shadow: 0 4px 24px rgba(0,0,0,0.5);
  pointer-events: none; z-index: 10; white-space: nowrap;
}
.portfolio-meta {
  padding: 28px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.portfolio-meta h3 { margin: 0; font-size: 22px; }

@media (min-width: 960px) {
  .portfolio-grid { grid-template-columns: 1fr 1fr; }
}

/* Styles from services.html */

/* ---- Services page ---- */
.tiers{padding:80px 0 120px}
.tier-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:18px;
}
.tier{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:24px;
  padding:40px 36px 36px;
  display:flex; flex-direction:column;
  position:relative;
  transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
.tier:hover{transform:translateY(-4px); border-color:var(--line-strong); box-shadow:0 20px 40px -20px rgba(11,11,11,.1)}
.tier.featured{background:var(--ink); color:var(--white); border-color:var(--ink)}
.tier.featured h2{color:var(--white)}
.tier.featured .tier-desc{color:rgba(255,255,255,.7)}
.tier.featured .tier-price{color:var(--lime)}
.tier.featured .tier-price small{color:rgba(255,255,255,.6)}
.tier.featured .tier-cta{background:var(--lime); color:var(--ink)}
.tier.featured .feat-list{color:rgba(255,255,255,.9); border-top-color:rgba(255,255,255,.1)}
.tier.featured .feat-list li::before{content:""; width:18px; height:18px; border-radius:0; background:transparent; flex:0 0 auto; margin-top:1px; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 92' fill='none'><path fill='%23C7FB3D' d='M40 2 L49 42 L53 42 L53 72 L58 72 L58 76 L63 76 Q65 84 40 84 Q15 84 17 76 L22 76 L22 72 L27 72 L27 42 L31 42 Z'/></svg>"); background-repeat:no-repeat; background-position:center; background-size:contain; width:16px; height:20px;}
.tier.featured .tier-tag{background:var(--lime); color:var(--ink); border-color:var(--lime)}
.tier-tag{
  align-self:flex-start;
  padding:5px 12px; border-radius:999px;
  background:transparent; color:var(--ink);
  border:1px solid var(--line);
  font-family:var(--font-mono); font-size:10px; font-weight:500;
  letter-spacing:0.14em; text-transform:uppercase;
  margin-bottom:28px;
}
.tier h2{font-size:30px; letter-spacing:-0.025em; margin-bottom:4px}
.tier-sub{font-size:14px; color:var(--muted); margin-bottom:18px; font-family:var(--font-mono); letter-spacing:0.06em}
.tier.featured .tier-sub{color:rgba(255,255,255,.55)}
.tier-price{
  display:flex; align-items:baseline; gap:8px;
  font-size:60px; font-weight:600; color:var(--ink);
  letter-spacing:-0.04em; line-height:1; margin:8px 0 22px;
}
.tier-price small{font-family:var(--font-mono); font-size:13px; color:var(--muted); font-weight:400; letter-spacing:0.05em}
.tier-desc{color:var(--muted); font-size:15.5px; line-height:1.55; margin-bottom:28px; min-height:48px}
.feat-list{
  list-style:none; padding:24px 0 0; margin:0 0 32px;
  display:flex; flex-direction:column; gap:14px;
  border-top:1px solid var(--line);
  font-size:15px;
  flex:1;
}
.feat-list li{display:flex; gap:12px; align-items:flex-start; line-height:1.45}
.feat-list li::before{
  content:""; width:18px; height:18px; border-radius:50%;
  background:var(--ink); flex:0 0 auto; margin-top:2px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 14 14'><path d='M3.5 7.2l2.2 2.2 5-5' stroke='%23C7FB3D' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:center;
}
.tier-cta{
  margin-top:auto; align-self:stretch;
  background:var(--ink); color:var(--white);
  padding:15px 22px; border-radius:999px;
  font-size:15px; font-weight:600;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition:transform .25s ease, background .25s ease;
}
.tier-cta:hover{transform:translateY(-1px)}
.tier-cta .arrow{transition:transform .25s ease}
.tier-cta:hover .arrow{transform:translateX(3px)}

/* Retainers */
.retainers{
  padding:100px 0 120px;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.retainers-head{
  display:grid; grid-template-columns:1fr 1fr; gap:48px;
  align-items:end; margin-bottom:56px;
}
.retainers-head .lede{color:var(--muted); font-size:18px; max-width:440px; margin-left:auto}
.retainers-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:16px;
}
.retainer{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:22px;
  padding:32px 28px;
  display:flex; flex-direction:column;
}
.retainer.best{border-color:var(--ink); position:relative}
.retainer-badge{
  position:absolute; top:-12px; left:24px;
  background:var(--lime); color:var(--ink);
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:0.14em; text-transform:uppercase;
  padding:5px 11px; border-radius:999px; font-weight:500;
}
.retainer h3{font-size:22px; margin-bottom:4px}
.retainer-sub{font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:18px}
.retainer-price{
  display:flex; align-items:baseline; gap:6px;
  font-size:40px; font-weight:600;
  letter-spacing:-0.03em; line-height:1;
  margin-bottom:8px;
}
.retainer-price small{font-family:var(--font-mono); font-size:12px; color:var(--muted); font-weight:400; letter-spacing:0.05em}
.retainer-alt{font-family:var(--font-mono); font-size:12px; color:var(--orange); margin-bottom:18px; letter-spacing:0.05em}
.retainer-desc{color:var(--muted); font-size:14.5px; line-height:1.5; margin-bottom:22px}
.retainer-list{list-style:none; padding:18px 0 0; margin:0 0 24px; display:flex; flex-direction:column; gap:10px; border-top:1px dashed var(--line); font-size:14px; color:var(--ink-2)}
.retainer-list li{display:flex; gap:10px; align-items:flex-start}
.retainer-list li::before{content:"·"; font-weight:700; color:var(--orange); flex:0 0 auto; line-height:1}

/* Add-ons strip */
.addons{padding:100px 0; background:var(--white)}
.addons-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:18px;
  margin-top:48px;
}
.addon{
  padding:24px;
  border:1px solid var(--line); border-radius:18px;
  background:var(--paper);
}
.addon b{display:block; font-size:17px; letter-spacing:-0.015em; margin-bottom:8px}
.addon p{font-size:14px; color:var(--muted); line-height:1.5}

/* CTA strip */
.cta-strip{
  background:var(--ink); color:var(--white);
  padding:100px 0;
  text-align:center;
}
.cta-strip h2{color:var(--white); font-size:clamp(36px, 5vw, 64px)}
.cta-strip h2 .lime{
  background:var(--lime); color:var(--ink);
  padding:0 .14em; border-radius:8px;
  display:inline-block; transform:rotate(-1deg);
}
.cta-strip p{font-size:19px; color:rgba(255,255,255,.7); max-width:560px; margin:24px auto 36px}

/* Responsive */
@media (max-width:960px){
  .tier-grid, .retainers-grid{grid-template-columns:1fr; gap:14px}
  .retainers-head{grid-template-columns:1fr; gap:20px; margin-bottom:36px}
  .retainers-head .lede{margin-left:0}
  .addons-grid{grid-template-columns:1fr 1fr; gap:12px}
  .tiers{padding:48px 0 80px}
  .retainers, .addons, .cta-strip{padding:64px 0}
}
@media (max-width:560px){
  .addons-grid{grid-template-columns:1fr}
}
