/* Field & Edge — redesigned in the Redscout system.
   Layered on ../colors_and_type.css, then re-skinned with the Field+Edge palette
   (periwinkle / linen / taupe). Fonts unchanged from the base system. */

:root{
  /* neutrals */
  --paper:        #F8F7F0;   /* Linen — page background */
  --paper-warm:   #EBE1D9;   /* Taupe — secondary background */
  --bone:         #E0D8CF;   /* Border — hairline fills */
  --line:         #E0D8CF;   /* Border — rules and dividers */
  --ink:          #1A1A1A;   /* Near-black — headings */
  --graphite:     #4A4A4A;   /* Body text */
  --smoke:        #8B8275;   /* warm muted — metadata */

  /* accent */
  --amber:        #8C95F8;   /* Periwinkle — hover, focus, emphasis */
  --amber-soft:   #C7CCFB;   /* periwinkle tint */

  /* inverse surfaces */
  --inverse-ink:  #1A1A1A;   /* dark sections / footer */
  --inverse-text: #F8F7F0;   /* Linen text on dark */

  /* mono — used for ledger labels and editorial tags */
  --mono: 'IBM Plex Mono','SFMono-Regular',ui-monospace,Menlo,monospace;
}

*{ box-sizing:border-box; }
@media (prefers-reduced-motion: no-preference){ html{ scroll-behavior:smooth; } }
body{ margin:0; font-family:var(--font-body); background:var(--paper); color:var(--fg1);
  -webkit-font-smoothing:antialiased; overflow-x:clip; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--amber); color:#fff; }

.wrap{ max-width:1240px; margin:0 auto; padding:0 56px; }
@media (max-width:760px){ .wrap{ padding:0 22px; } }

/* ---------- type helpers ---------- */
.display{ font-family:var(--font-display); font-weight:600; text-transform:uppercase;
  letter-spacing:-0.005em; line-height:0.94; color:var(--fg1); margin:0; }
.eyebrow{ font-family:var(--font-eyebrow); font-size:12px; font-weight:600;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--fg3); margin:0; }
.eyebrow-rule{ border-top:none; padding-top:0; }
.lead{ font-family:var(--font-body); font-size:20px; line-height:1.55; color:var(--fg2); margin:0; }
.body{ font-family:var(--font-body); font-size:16px; line-height:1.65; color:var(--fg2); margin:0; }
.section{ padding:120px 0; }
@media (max-width:760px){ .section{ padding:72px 0; } }

/* ---------- buttons / links ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-eyebrow);
  font-size:12px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase;
  padding:15px 24px; border-radius:var(--radius-pill); background:var(--ink); color:var(--paper);
  border:1px solid var(--ink); position:relative; transition:background var(--dur-quick) var(--ease-standard); }
.btn::after{ content:""; position:absolute; left:24px; right:24px; bottom:11px; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform var(--dur-base) var(--ease-standard); }
.btn:hover::after{ transform:scaleX(1); }
.btn.ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn.inv{ background:var(--paper); color:var(--ink); border-color:var(--paper); }
.link{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-eyebrow);
  font-size:12px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:var(--fg1);
  transition:color var(--dur-quick) var(--ease-standard); }
.link .arw{ transition:transform var(--dur-quick) var(--ease-standard); }
.link:hover{ color:var(--amber); } .link:hover .arw{ transform:translateX(4px); }

/* ---------- header ---------- */
.hdr{ position:sticky; top:0; z-index:60; transition:background .3s, border-color .3s; border-bottom:1px solid transparent; }
.hdr.scrolled{ background:rgba(255,255,255,.9); backdrop-filter:saturate(180%) blur(8px); border-bottom-color:var(--bone); }
.hdr-in{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.logo{ height:26px; }
.logo img{ height:100%; width:auto; }
.nav{ display:flex; align-items:center; gap:30px; }
.nav a.eyebrow{ color:var(--fg3); transition:color var(--dur-quick); }
.nav a.eyebrow:hover{ color:var(--amber); }
.nav-cta{ margin-left:6px; }
.burger{ display:none; background:none; border:none; flex-direction:column; gap:5px; padding:6px; }
.burger span{ width:22px; height:2px; background:var(--ink); display:block; }
@media (max-width:860px){ .nav .nav-link{ display:none; } .burger{ display:flex; } }

/* mobile nav sheet */
.msheet{ position:fixed; inset:0; z-index:70; background:var(--paper); transform:translateY(-100%);
  transition:transform .45s var(--ease-standard); display:flex; flex-direction:column; padding:24px 22px; }
.msheet.open{ transform:none; }
.msheet .mrow{ display:flex; justify-content:space-between; align-items:center; height:72px; }
.msheet nav{ display:flex; flex-direction:column; gap:6px; margin-top:24px; }
.msheet nav a{ font-family:var(--font-display); text-transform:uppercase; font-weight:600;
  font-size:44px; line-height:1.05; color:var(--ink); border-bottom:1px solid var(--bone); padding:14px 0; }

/* ---------- hero ---------- */
.hero{ padding:60px 0 80px; }
.hero-grid{ display:grid; grid-template-columns:1.35fr 1fr; gap:56px; align-items:end; }
@media (max-width:900px){ .hero-grid{ grid-template-columns:1fr; gap:36px; } }
.hero h1{ font-size:clamp(38px,6.1vw,90px); }
.hero .mask>span{ white-space:nowrap; }
.hero .rotate-line{ color:var(--amber); display:block; }
.hero .mask{ display:block; overflow:hidden; }
.hero .mask>span{ display:block; will-change:transform; }
.hero-media{ position:relative; aspect-ratio:4/5; border-radius:4px; overflow:hidden; background:var(--bone); }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.tagrow{ display:flex; flex-wrap:wrap; gap:10px 14px; margin-top:30px; }
.tag{ font-family:var(--font-eyebrow); font-size:12px; letter-spacing:0.04em; text-transform:uppercase;
  color:var(--fg3); border:1px solid var(--bone); border-radius:var(--radius-pill); padding:7px 14px; }
.hero-cta{ display:flex; align-items:center; gap:20px; margin-top:34px; flex-wrap:wrap; }

/* ---------- marquee ---------- */
.marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:18px 0; overflow:hidden; background:var(--paper-warm); }
.marquee-track{ display:flex; gap:48px; width:max-content; animation:fe-marq 38s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-item{ font-family:var(--font-display); font-weight:600; text-transform:uppercase; font-size:13px;
  letter-spacing:0.01em; color:var(--ink); display:inline-flex; align-items:center; gap:48px; white-space:nowrap; }
.marquee-item .dot{ color:var(--amber); }
@keyframes fe-marq{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
@media (prefers-reduced-motion:reduce){ .marquee-track{ animation:none; } }

/* ---------- section head ---------- */
.shead{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:48px; }
.shead .display{ font-size:clamp(30px,4vw,60px); }
.shead p.body{ max-width:440px; }

/* ---------- services (featured spotlight) ---------- */
.spot{ display:grid; grid-template-columns:1.1fr 1fr; gap:18px; }
@media (max-width:860px){ .spot{ grid-template-columns:1fr; } }
.spot-feat{ background:var(--ink); color:var(--inverse-text); border-radius:var(--radius-lg); padding:48px 44px;
  position:relative; overflow:hidden; display:flex; flex-direction:column; gap:28px; min-height:440px; }
.spot-feat::after{ content:""; position:absolute; right:-120px; top:-120px; width:300px; height:300px;
  border-radius:50%; background:var(--amber); opacity:0.16; filter:blur(8px); }
.spot-feat > *{ position:relative; z-index:2; }
.spot-feat .feat-body{ flex:1; display:flex; flex-direction:column; }
.spot-feat .feat-body h3{ margin-top:auto; }
.feat-monitor{ position:relative; width:100%; height:132px; border-top:1px solid rgba(245,242,236,0.14); padding-top:6px; }
.feat-monitor canvas{ position:absolute; left:0; bottom:0; }
.spot-feat .pop{ align-self:flex-start; font-family:var(--font-eyebrow); font-size:9px; letter-spacing:0.12em;
  text-transform:uppercase; color:#fff; background:var(--amber); padding:5px 11px; border-radius:var(--radius-pill); }
.spot-feat .num{ font-family:var(--font-eyebrow); font-size:12px; letter-spacing:0.14em; color:var(--amber-soft); }
.spot-feat .verb{ font-family:var(--font-display); text-transform:uppercase; font-weight:600; font-size:66px;
  line-height:0.92; color:#fff; margin:6px 0 18px; }
.spot-feat h3{ font-family:var(--font-body); font-size:19px; font-weight:600; color:#fff; margin:0 0 12px; }
.spot-feat p{ font-size:16px; line-height:1.6; color:#d8d4cc; margin:0 0 26px; max-width:380px; }
.spot-feat .link{ color:#fff; }
.spot-feat .link:hover{ color:var(--amber-soft); }
.spot-stack{ display:flex; flex-direction:column; gap:18px; }
.scard{ background:var(--paper-warm); border-radius:var(--radius-lg); padding:26px 30px; flex:1;
  display:flex; align-items:center; gap:24px; transition:background var(--dur-base) var(--ease-standard); }
.scard:hover{ background:var(--bone); }
.scard-txt{ flex:1; min-width:0; display:flex; flex-direction:column; }
.svc-anim{ position:relative; flex:none; width:116px; height:116px; align-self:center; }
.svc-anim canvas{ position:absolute; inset:0; }
@media (max-width:520px){ .svc-anim{ width:88px; height:88px; } }
.scard .num{ font-family:var(--font-eyebrow); font-size:11px; letter-spacing:0.14em; color:var(--fg3); }
.scard .verb{ font-family:var(--font-display); text-transform:uppercase; font-weight:600; font-size:32px;
  line-height:1; color:var(--ink); margin:6px 0 8px; }
.scard p{ font-size:14px; line-height:1.55; color:var(--fg2); margin:0 0 14px; max-width:380px; }
.scard .link{ font-size:11px; }

/* ---------- insights ---------- */
.cats{ display:flex; flex-wrap:wrap; gap:9px; margin-bottom:40px; }
.cat{ font-family:var(--font-eyebrow); font-size:11px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--fg2); border:1px solid var(--line); border-radius:var(--radius-pill); padding:8px 16px;
  background:transparent; transition:all var(--dur-quick); }
.cat.active,.cat:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.art-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:36px 28px; align-items:start; }
@media (max-width:900px){ .art-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .art-grid{ grid-template-columns:1fr; } }
.art{ cursor:pointer; }
.art .thumb{ width:100%; aspect-ratio:3/2; border-radius:4px; overflow:hidden; background:var(--bone); }
.art .thumb img{ width:100%; height:100%; object-fit:cover; transition:transform var(--dur-slow) var(--ease-standard); }
.art:hover .thumb img{ transform:scale(1.04); }
.art .meta{ margin-top:16px; }
.art .meta .eyebrow{ margin-bottom:9px; }
.art h3{ font-family:var(--font-body); font-size:19px; font-weight:500; line-height:1.3; color:var(--ink); margin:0; }
.art h3 .u{ transition:color var(--dur-base) var(--ease-standard); }
.art:hover h3 .u{ color:var(--amber); }
.art .foot{ display:flex; justify-content:space-between; align-items:center; margin-top:14px; }
.art .read{ font-size:10px; letter-spacing:0.04em; text-transform:uppercase; color:var(--fg3); border:1px solid var(--bone); border-radius:var(--radius-pill); padding:3px 9px; }
.art.featured{ grid-column:1 / -1; display:grid; grid-template-columns:1.2fr 1fr; gap:40px; align-items:center; margin-bottom:8px; }
@media (max-width:600px){ .art.featured{ grid-template-columns:1fr; gap:24px; } }
.art.featured .thumb{ aspect-ratio:16/10; }
.art.featured h3{ font-size:clamp(28px,3.4vw,44px); font-weight:600; font-family:var(--font-display); text-transform:uppercase; line-height:1.02; }

/* ---------- newsletter ---------- */
.news{ background:var(--paper-warm); }
.news-in{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
@media (max-width:760px){ .news-in{ grid-template-columns:1fr; gap:24px; } }
.nl-form{ display:flex; gap:0; border-bottom:1px solid var(--line); }
.nl-form input{ flex:1; background:transparent; border:none; outline:none; font-family:var(--font-body);
  font-size:18px; color:var(--ink); padding:12px 0; caret-color:var(--amber); }
.nl-form input::placeholder{ color:var(--fg3); }
.nl-form button{ background:none; border:none; color:var(--ink); padding:0 8px; }

/* ---------- proof / trust signals ---------- */
.proof{ background:var(--inverse-ink); color:var(--inverse-text); }
.proof .eyebrow{ color:#7A7A7A; border-color:#2a2a2a; }
.proof-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:32px; margin-bottom:64px; }
.proof-head .eyebrow-rule{ border-color:#2a2a2a; }
.proof-head .display{ font-size:clamp(30px,4vw,60px); color:var(--inverse-text); }
@media (max-width:680px){ .proof-head{ flex-direction:column; align-items:flex-start; gap:18px; } }
.qmark{ font-family:var(--font-display); font-weight:600; color:var(--amber); line-height:0.6; display:block; }
.q-lead{ margin:0 0 64px; max-width:1080px; }
.q-lead .qmark{ font-size:64px; margin-bottom:6px; }
.q-lead blockquote{ margin:0; font-family:var(--font-body); font-weight:400;
  font-size:clamp(24px,3.1vw,44px); line-height:1.26; letter-spacing:-0.01em; color:var(--inverse-text); }
.q-lead figcaption{ margin-top:26px; display:flex; flex-wrap:wrap; align-items:baseline; gap:7px 14px;
  font-family:var(--font-eyebrow); font-size:12px; font-weight:600; letter-spacing:0.16em; text-transform:uppercase; }
.q-lead figcaption b{ color:var(--inverse-text); font-weight:600; }
.q-lead figcaption span{ color:var(--amber); }
.q-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:860px){ .q-grid{ grid-template-columns:1fr; gap:14px; } }
.qcard{ margin:0; display:flex; flex-direction:column; padding:32px 30px; border:1px solid #2a2a2a;
  border-radius:var(--radius-lg); transition:border-color var(--dur-base) var(--ease-standard), background var(--dur-base) var(--ease-standard); }
.qcard:hover{ border-color:#3f3f3f; background:rgba(245,242,236,0.02); }
.qcard .qmark{ font-size:40px; margin-bottom:14px; opacity:0.85; }
.qcard blockquote{ margin:0; flex:1; font-family:var(--font-body); font-size:16px; line-height:1.62; color:#cfccc4; }
.qcard figcaption{ margin-top:26px; padding-top:20px; border-top:1px solid #2a2a2a; display:flex; flex-direction:column; gap:7px; }
.qcard figcaption b{ font-family:var(--font-display); text-transform:uppercase; font-weight:600; font-size:19px; letter-spacing:0.01em; color:var(--inverse-text); line-height:1; }
.qcard figcaption span{ font-family:var(--font-eyebrow); font-size:11px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:#7A7A7A; }

/* ---------- about ---------- */
.about-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:start; }
@media (max-width:860px){ .about-grid{ grid-template-columns:1fr; gap:36px; } }
.portrait{ width:100%; aspect-ratio:1/1; border-radius:4px; overflow:hidden; background:var(--bone); cursor:pointer; }
.portrait img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.03);
  transition:filter var(--dur-base) var(--ease-standard); }
.portrait:hover img{ filter:grayscale(0) contrast(1); }
.langs{ display:flex; flex-direction:column; gap:0; margin:30px 0; border-top:1px solid var(--bone); }
.lang{ display:grid; grid-template-columns:200px 1fr; gap:20px; padding:20px 0; border-bottom:1px solid var(--bone); }
@media (max-width:600px){ .lang{ grid-template-columns:1fr; gap:6px; } }
.lang .l{ font-family:var(--font-display); text-transform:uppercase; font-weight:600; font-size:22px; color:var(--ink); line-height:1; }
.lang .r{ font-size:15px; line-height:1.55; color:var(--fg2); }
.bglist{ display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.bgitem{ font-family:var(--font-eyebrow); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; white-space:nowrap; color:var(--fg3); border:1px solid var(--bone); border-radius:var(--radius-pill); padding:7px 14px; }

/* ---------- cta band ---------- */
.cta{ background:var(--inverse-ink); color:var(--inverse-text); text-align:center; }
.cta .display{ font-size:clamp(40px,6vw,104px); color:var(--inverse-text); }
.cta .lead{ color:#b8b4ac; max-width:560px; margin:22px auto 0; }
.cta .row{ display:flex; gap:16px; justify-content:center; margin-top:36px; flex-wrap:wrap; }

/* ---------- contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; gap:40px; } }
.cform{ display:flex; flex-direction:column; gap:24px; }
.fld{ display:flex; flex-direction:column; gap:8px; }
.fld label{ font-family:var(--font-eyebrow); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; color:var(--fg3); }
.fld input,.fld textarea{ background:transparent; border:none; border-bottom:1px solid var(--line);
  font-family:var(--font-body); font-size:17px; color:var(--ink); padding:9px 0; outline:none;
  caret-color:var(--amber); transition:border-color var(--dur-quick); resize:vertical; }
.fld input:focus,.fld textarea:focus{ border-color:var(--amber); }
.steps{ display:flex; flex-direction:column; gap:0; }
.step{ display:grid; grid-template-columns:48px 1fr; gap:18px; padding:22px 0; border-top:1px solid var(--bone); }
.step:last-child{ border-bottom:1px solid var(--bone); }
.step .n{ font-family:var(--font-display); font-weight:600; font-size:34px; color:var(--amber); line-height:1; }
.step h4{ font-family:var(--font-body); font-weight:600; font-size:17px; color:var(--ink); margin:0 0 5px; }
.step p{ font-size:14px; line-height:1.5; color:var(--fg2); margin:0; }
.sent{ font-family:var(--font-display); text-transform:uppercase; font-size:34px; color:var(--ink); }

/* ---------- footer ---------- */
footer.foot{ background:var(--inverse-ink); color:var(--inverse-text); padding:72px 0 36px; }
.foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; padding-bottom:56px; border-bottom:1px solid #2a2a2a; }
@media (max-width:760px){ .foot-top{ grid-template-columns:1fr 1fr; gap:32px; } }
footer.foot .logo img{ height:26px; filter:brightness(0) invert(1); }
footer.foot .fcol h5{ font-family:var(--font-eyebrow); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:#7A7A7A; margin:0 0 16px; }
footer.foot .fcol a{ display:block; font-size:15px; color:#d8d4cc; padding:6px 0; transition:color var(--dur-quick); }
footer.foot .fcol a:hover{ color:var(--amber); }
.foot-bot{ display:flex; justify-content:space-between; align-items:center; padding-top:26px; flex-wrap:wrap; gap:14px; }
.foot-bot .eyebrow{ color:#7A7A7A; }

/* ---------- reveal ---------- */
.reveal{ opacity:1; }
@keyframes fe-rise{ 0%{opacity:0;transform:translateY(26px)} 100%{opacity:1;transform:none} }
.reveal.in{ animation:fe-rise var(--dur-slow) var(--ease-entrance) both; }

/* Staggered child reveal — opt in by adding .stagger to the parent.
   Children animate in sequence. Pure-CSS fallback: if .in is never added by JS,
   children still reveal automatically after a 400ms delay so content is never stuck hidden. */
.stagger > *{ animation:fe-rise 720ms var(--ease-entrance) 400ms both; }
.stagger.in > *:nth-child(1){ animation-delay:60ms; }
.stagger.in > *:nth-child(2){ animation-delay:140ms; }
.stagger.in > *:nth-child(3){ animation-delay:220ms; }
.stagger.in > *:nth-child(4){ animation-delay:300ms; }
.stagger.in > *:nth-child(5){ animation-delay:380ms; }
.stagger.in > *:nth-child(6){ animation-delay:460ms; }
.stagger.in > *:nth-child(7){ animation-delay:540ms; }
.stagger.in > *:nth-child(8){ animation-delay:620ms; }
.stagger.in > *:nth-child(9){ animation-delay:700ms; }
.stagger.in > *:nth-child(10){ animation-delay:780ms; }
.stagger.in > *:nth-child(n+11){ animation-delay:860ms; }

/* Hero illustration: subtle scale-in on load */
@keyframes fe-zoom-in{ 0%{opacity:0;transform:scale(.96)} 100%{opacity:1;transform:none} }
.hero-media{ animation:fe-zoom-in 1100ms var(--ease-entrance) both; animation-delay:200ms; }

/* Tag chips: gentle hover lift */
.tag{ transition:transform var(--dur-quick) var(--ease-standard), border-color var(--dur-quick), color var(--dur-quick); }
.tag:hover{ transform:translateY(-2px); border-color:var(--amber); color:var(--ink); }

/* Pillar stats: rise + accent flash when group reveals */
@keyframes fe-stat-rise{ 0%{opacity:0;transform:translateY(40px)} 60%{opacity:1;color:var(--amber);transform:translateY(-3px)} 100%{opacity:1;color:var(--inverse-text);transform:none} }
.stagger.in .pillar-stat{ animation:fe-stat-rise 1100ms var(--ease-entrance) both; animation-delay:300ms; }

@media (prefers-reduced-motion:reduce){
  .reveal.in,.stagger.in > *,.hero-media,.stagger.in .pillar-stat{ animation:none; opacity:1; transform:none; }
}
