/* London Free Guide — "Work with us" / LFG Studio page.
   Page-specific styles. Loads AFTER home.css; theme.css loads after this.
   Reuses brand tokens, nav, footer, .btn, .wrap from home.css. */

/* ---------- shared section rhythm ---------- */
.ww-main { padding-bottom: 0; }
/* the last plain section before the footer (About) doesn't need full padding —
   the main pages fill this area with the newsletter band instead */
.ww-main > .sec:last-child { padding-bottom: 18px; }
.kicker {
  font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; font-size: .7rem; color: var(--lfg-accent);
  display: inline-block; margin-bottom: 14px;
}
.kicker.muted { color: var(--lfg-white-50); }
.sec { padding: 46px 0; border-top: 1px solid var(--lfg-white-08); scroll-margin-top: 78px; }
.sec:first-of-type { border-top: 0; }
.sec h2 {
  font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: clamp(1.7rem, 3.6vw, 2.6rem); line-height: 1.02; margin: 0 0 14px;
  padding-top: .04em;
}
.sec h2 em { font-style: normal; color: var(--lfg-accent); }
.sec .lead { color: var(--lfg-white-70); font-size: 1.04rem; line-height: 1.6;
  max-width: 60ch; text-wrap: pretty; }

/* ---------- hero ---------- */
.ww-hero { padding: 54px 0 8px; }
@media (min-width: 860px) {
  .ww-hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: start; }
  .ww-hero-grid .sub { margin-top: 0; }
}
.ww-hand {
  font-family: var(--lfg-font-hand); color: var(--lfg-accent);
  font-size: clamp(1.5rem, 5.5vw, 2.1rem); line-height: 1.15; display: block; margin-bottom: 20px;
}
.ww-hero h1 {
  font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  line-height: .9; font-size: clamp(2.3rem, 5.5vw, 4rem); margin: 0; max-width: 16ch;
  letter-spacing: -.01em;
}
.ww-hero h1 em { font-style: normal; color: var(--lfg-accent); }
.ww-hero .sub { color: var(--lfg-white-70); font-size: 1.12rem; line-height: 1.6;
  max-width: 56ch; margin: 22px 0 0; text-wrap: pretty; }
.ww-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.btn.ghost { background: transparent; color: var(--lfg-white-90);
  border: 1px solid var(--lfg-white-30); }
.btn.ghost:hover { border-color: var(--lfg-white); color: #fff; }
.btn.lg { padding: .8rem 1.4rem; font-size: .82rem; }

/* ---------- two tracks ---------- */
.tracks { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 760px) { .tracks { grid-template-columns: 1fr 1fr; gap: 18px; } }
.track {
  position: relative; background: #161616; border: 1px solid var(--lfg-white-08);
  border-radius: var(--lfg-radius-lg, 18px); padding: 30px 28px 26px; overflow: hidden;
  display: flex; flex-direction: column;
}
.track::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 6px;
  background: var(--lfg-accent); }
.track .tnum { font-family: var(--lfg-font-head); font-weight: 700; color: var(--lfg-white-15);
  font-size: 3rem; line-height: 1; position: absolute; right: 22px; top: 16px; }
.track h3 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: 1.6rem; line-height: 1; margin: 0 0 10px; }
.track p { color: var(--lfg-white-70); font-size: .96rem; line-height: 1.55; margin: 0 0 18px;
  max-width: 38ch; }
.track .tlink { margin-top: auto; font-family: var(--lfg-font-body); font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em; font-size: .78rem; color: var(--lfg-accent); }
.track .tlink:hover { color: #fff; }

/* ---------- services grid ---------- */
.svc-grid { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 8px; }
@media (min-width: 640px) { .svc-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .svc-grid { grid-template-columns: repeat(3, 1fr); } }
.svc {
  background: #141414; border: 1px solid var(--lfg-white-08);
  border-radius: var(--lfg-radius-md, 14px); padding: 24px 22px;
}
.svc .bar { width: 44px; height: 3px; background: var(--lfg-accent); border-radius: 2px; margin-bottom: 16px; }
.svc h4 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: 1.18rem; line-height: 1.02; margin: 0 0 9px; }
.svc p { color: var(--lfg-white-70); font-size: .9rem; line-height: 1.55; margin: 0; }
.svc .tag { display: inline-block; margin-top: 14px; font-family: var(--lfg-font-body);
  font-weight: 600; font-size: .66rem; text-transform: uppercase; letter-spacing: .05em;
  color: var(--lfg-white-50); border: 1px solid var(--lfg-white-15); border-radius: 999px;
  padding: 4px 10px; }

/* ---------- packages ---------- */
.pkgs { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 8px; }
@media (min-width: 820px) { .pkgs { grid-template-columns: repeat(3, 1fr); } }
.pkg { background: #161616; border: 1px solid var(--lfg-white-08);
  border-radius: var(--lfg-radius-md, 14px); padding: 26px 24px; display: flex; flex-direction: column; }
.pkg.feature { border-color: color-mix(in srgb, var(--lfg-accent) 55%, transparent);
  background: color-mix(in srgb, var(--lfg-accent) 8%, #161616); }
.pkg .ptag { font-family: var(--lfg-font-body); font-weight: 700; font-size: .64rem;
  text-transform: uppercase; letter-spacing: .08em; color: var(--lfg-accent); margin-bottom: 10px; }
.pkg h4 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: 1.5rem; line-height: 1; margin: 0 0 6px; }
.pkg .who { color: var(--lfg-white-50); font-size: .82rem; margin: 0 0 18px; }
.pkg ul { list-style: none; padding: 0; margin: 0 0 22px; display: grid; gap: 10px; }
.pkg li { position: relative; padding-left: 24px; color: var(--lfg-white-90); font-size: .9rem;
  line-height: 1.4; }
.pkg li::before { content: ""; position: absolute; left: 0; top: 6px; width: 11px; height: 7px;
  border-left: 2px solid var(--lfg-accent); border-bottom: 2px solid var(--lfg-accent);
  transform: rotate(-45deg); }
.pkg .price { margin-top: auto; }
.pkg .price .from { font-family: var(--lfg-font-body); font-weight: 600; font-size: .9rem;
  color: var(--lfg-white-90); display: block; margin-bottom: 4px; }
.pkg .btn { width: 100%; text-align: center; margin-top: 12px; }
.pkg .btn.ghost { background: transparent; }

/* ---------- featured: what a feature costs (2-up) ---------- */
.feat-cost { margin-top: 32px; }
.pkgs.duo { grid-template-columns: 1fr; max-width: 720px; }
@media (min-width: 720px) { .pkgs.duo { grid-template-columns: 1fr 1fr; } }

/* ---------- studio proof strip ---------- */
.proof { margin-top: 32px; }
.proof-note { font-family: var(--lfg-font-hand); color: var(--lfg-white); font-size: 1.7rem; line-height: 1.1; margin: 0 0 16px; }
.proof-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 720px) { .proof-row { grid-template-columns: repeat(4, 1fr); } }
.proof-row img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; border-radius: var(--lfg-radius-md, 14px); border: 1px solid var(--lfg-white-08); display: block; }
[data-theme="light"] .proof-row img { border-color: rgba(28,20,13,0.08); box-shadow: 0 10px 30px rgba(28,20,13,0.06); }

/* ---------- featured / transparency ---------- */
.feat-wrap { display: grid; grid-template-columns: 1fr; gap: 18px; align-items: start; }
@media (min-width: 820px) { .feat-wrap { grid-template-columns: 1.1fr .9fr; gap: 34px; } }
.transp {
  background: #141414; border: 1px solid var(--lfg-white-08);
  border-left: 6px solid var(--lfg-accent); border-radius: var(--lfg-radius-md, 14px);
  padding: 24px 26px;
}
.transp h4 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: 1.15rem; margin: 0 0 12px; }
.transp .row { display: flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--lfg-white-08);
  color: var(--lfg-white-90); font-size: .92rem; line-height: 1.5; }
.transp .row:first-of-type { border-top: 0; }
.transp .row b { color: #fff; }
.transp .dot { flex-shrink: 0; width: 9px; height: 9px; border-radius: 50%; margin-top: 6px; }
.transp .dot.free { background: var(--lfg-go-green, #2ECC40); }
.transp .dot.paid { background: var(--lfg-accent); }

/* ---------- intake form ---------- */
.form-sec { background: #121212; border-top: 1px solid var(--lfg-white-08);
  border-bottom: 1px solid var(--lfg-white-08); }
[data-theme="light"] .form-sec { background: #efe8dc; }
.form-card { background: #181818; border: 1px solid var(--lfg-white-08);
  border-radius: var(--lfg-radius-lg, 18px); padding: 30px 28px; max-width: 760px; }
[data-theme="light"] .form-card { background: #ffffff; }
.form-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 620px) { .form-grid { grid-template-columns: 1fr 1fr; }
  .field.full { grid-column: 1 / -1; } }
.field label { display: block; font-family: var(--lfg-font-body); font-weight: 600;
  font-size: .8rem; color: var(--lfg-white-90); margin-bottom: 7px; }
.field label .req { color: var(--lfg-accent); }
.field label .opt { color: var(--lfg-white-30); font-weight: 500; }
.field input, .field textarea, .field select {
  width: 100%; background: var(--lfg-black); border: 1px solid var(--lfg-white-15);
  color: var(--lfg-white); font: inherit; font-size: .92rem; padding: .68rem .8rem;
  border-radius: 10px; transition: border-color .15s;
}
[data-theme="light"] .field input, [data-theme="light"] .field textarea,
[data-theme="light"] .field select { background: #f4f0ea; }
.field input::placeholder, .field textarea::placeholder { color: var(--lfg-white-30); }
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--lfg-accent); }
.field textarea { resize: vertical; min-height: 84px; }
.field .hint { font-size: .72rem; color: var(--lfg-white-50); margin-top: 6px; }
.field.invalid input, .field.invalid textarea { border-color: var(--lfg-accent); }

.form-foot { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.form-foot .note { font-size: .76rem; color: var(--lfg-white-50); flex: 1; min-width: 200px; }

/* confirmation state */
.form-done { display: none; }
.form-card.sent .form-grid, .form-card.sent .form-foot, .form-card.sent .form-intro { display: none; }
.form-card.sent .form-done { display: block; }
.form-done .check { width: 54px; height: 54px; border-radius: 50%; background: var(--lfg-accent);
  display: grid; place-items: center; margin-bottom: 18px; }
.form-done .check::after { content: ""; width: 20px; height: 11px; border-left: 3px solid #fff;
  border-bottom: 3px solid #fff; transform: rotate(-45deg); margin-top: -4px; }
.form-done h3 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: 1.7rem; margin: 0 0 10px; }
.form-done p { color: var(--lfg-white-70); font-size: .96rem; line-height: 1.55; max-width: 46ch; margin: 0 0 22px; }
.summary { background: var(--lfg-black); border: 1px solid var(--lfg-white-08); border-radius: 12px;
  padding: 18px 20px; margin-bottom: 22px; }
[data-theme="light"] .summary { background: #f4f0ea; }
.summary .srow { display: flex; gap: 12px; padding: 7px 0; font-size: .86rem; line-height: 1.4;
  border-top: 1px solid var(--lfg-white-08); }
.summary .srow:first-child { border-top: 0; }
.summary .sk { flex: 0 0 116px; color: var(--lfg-white-50); font-weight: 600; }
.summary .sv { color: var(--lfg-white-90); flex: 1; min-width: 0; }
.send-row { display: flex; flex-wrap: wrap; gap: 10px; }
.btn.wa { background: #25D366; color: #08231a; }
.btn.wa:hover { filter: brightness(1.06); }

/* ---------- reach strip (quiet) ---------- */
.reach { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.reach .chip { display: inline-flex; align-items: center; gap: 7px; background: #161616;
  border: 1px solid var(--lfg-white-08); border-radius: 999px; padding: 8px 14px;
  font-size: .82rem; color: var(--lfg-white-70); font-weight: 500; }
[data-theme="light"] .reach .chip { background: #ffffff; }
.reach .chip b { color: var(--lfg-white); font-weight: 600; }

/* ---------- about page ---------- */
.about-hero-intro { color: var(--lfg-white-70); font-size: 1.15rem; line-height: 1.5; margin: 18px 0 0; max-width: 32ch; text-wrap: pretty; }
.about-portrait { position: relative; }
.about-portrait::before { content: ""; position: absolute; top: -10%; right: 2%; width: 62%; height: 62%; border-radius: 50%; pointer-events: none; z-index: 0; background: radial-gradient(circle, color-mix(in srgb, var(--lfg-accent) 26%, transparent), transparent 70%); }
.about-portrait img { position: relative; z-index: 1; display: block; width: 100%; height: auto; border-radius: 18px; border: 1px solid var(--lfg-white-15); box-shadow: 0 24px 60px rgba(0,0,0,.45); }
[data-theme="light"] .about-portrait img { border-color: rgba(28,20,13,.12); box-shadow: 0 24px 60px rgba(28,20,13,.18); }
@media (min-width: 820px) {
  .about-hero { padding: 40px 0 26px; }
  .about-hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 34px; align-items: center; }
  .about-portrait img { max-height: 330px; object-fit: cover; object-position: center 16%; }
}
@media (max-width: 819px) {
  .about-portrait img { max-width: 300px; margin: 20px 0 0; }
  .about-portrait::before { display: none; }
}
.about-bio p { color: var(--lfg-white-90); font-size: 1.06rem; line-height: 1.7; margin: 0 0 18px; text-wrap: pretty; }
.about-bio p:first-child { font-size: 1.3rem; line-height: 1.5; font-weight: 500; color: var(--lfg-white); }
.about-bio p:last-child { margin-bottom: 0; }
.about-bio a { color: var(--lfg-accent); font-weight: 600; }
.about-bio a:hover { color: var(--lfg-white); }

/* ---------- contact cta ---------- */
.ww-cta { text-align: center; padding: 56px 0; scroll-margin-top: 78px; }
.ww-cta h2 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  font-size: clamp(2rem, 5vw, 3rem); line-height: .94; margin: 0 0 12px; }
.ww-cta h2 em { font-style: normal; color: var(--lfg-accent); }
.ww-cta p { color: var(--lfg-white-70); margin: 0 auto 22px; max-width: 44ch; }
.ww-cta .alt { font-size: .82rem; color: var(--lfg-white-50); margin-top: 16px; }
.ww-cta .alt a { color: var(--lfg-white-90); font-weight: 600; }

/* ---------- light-mode surface overrides ---------- */
/* these cards hardcode dark fills, so flip them to white in light mode
   (text uses the token ladder, which already flips to dark) */
[data-theme="light"] .track,
[data-theme="light"] .svc,
[data-theme="light"] .pkg,
[data-theme="light"] .transp { background: #ffffff; }
[data-theme="light"] .pkg.feature { background: color-mix(in srgb, var(--lfg-accent) 8%, #ffffff); }
[data-theme="light"] .track .tnum { color: rgba(28,20,13,0.10); }
[data-theme="light"] .svc .tag { border-color: var(--lfg-white-15); }
[data-theme="light"] .track,
[data-theme="light"] .svc,
[data-theme="light"] .pkg,
[data-theme="light"] .transp { box-shadow: 0 10px 30px rgba(28,20,13,0.06); }
[data-theme="light"] .transp .row b { color: var(--lfg-white); }
