/* Octopus Investments - editorial system v2 */
:root{
  --bg:#ffffff; --bg-2:#f5f8fa; --bg-3:#edf3f6;
  --ink:#0b2236; --body:#41525f; --muted:#74838f;
  --line:rgba(12,28,46,.15); --line-soft:rgba(12,28,46,.07);
  --navy:#0c2c46; --abyss:#071a2c;
  --accent:#FF69B4; --accent-deep:#d63a8f; --accent-soft:rgba(255,105,180,.16);
  --serif:'Cormorant Garamond','EB Garamond',Georgia,serif;
  --sans:'EB Garamond',Georgia,serif;
  --wrap:1200px; --col:760px; --sec:clamp(3.5rem,7vw,5.5rem);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);font-size:19px;line-height:1.68;color:var(--body);background:var(--bg);-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
img{max-width:100%;display:block;height:auto}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--accent-deep)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
::selection{background:var(--accent-soft);color:var(--ink)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.06;color:var(--ink);margin:0 0 .5em;letter-spacing:-.01em}
h1{font-size:clamp(2.9rem,6.4vw,5.2rem)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:1.5rem}
p{margin:0 0 1.1em}
em,i{font-style:italic;color:var(--ink)}
strong{color:var(--ink);font-weight:600}
.skip{position:absolute;left:-999px}.skip:focus{left:12px;top:12px;background:var(--accent);color:#fff;padding:10px 16px;z-index:300}

/* wayfinding */
.eyebrow{display:flex;align-items:center;gap:13px;text-transform:uppercase;letter-spacing:.24em;font-size:.72rem;font-weight:600;color:var(--navy);margin:0 0 1.6em}
.eyebrow::before{content:"";width:20px;height:20px;flex:none;background:var(--navy);-webkit-mask:url('octopus-mark.svg?v=4') center/contain no-repeat;mask:url('octopus-mark.svg?v=4') center/contain no-repeat}
.eyebrow.center{justify-content:center}
.marker{display:flex;align-items:center;gap:18px;margin:0 0 38px}
.marker .num{font-family:var(--serif);font-style:italic;color:var(--navy);font-size:1.4rem;flex:none}
.marker .lab{text-transform:uppercase;letter-spacing:.24em;font-size:.72rem;font-weight:600;color:var(--muted);flex:none}
.marker .rule{height:2px;background:var(--accent);flex:none;width:40px}
.marker::after{content:"";height:1px;background:var(--line);flex:1}

/* header */
.site-head{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft)}
.head-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink);font-family:var(--serif);font-size:1.3rem;letter-spacing:.03em}
.brand:hover{color:var(--ink)}
.brand b{font-weight:600}
.brand em{font-style:italic;margin-left:.32em;background:linear-gradient(transparent 62%, var(--accent-soft) 62%);padding:0 .12em}
.brand-mark{width:30px;height:30px;flex:none;background:var(--navy);-webkit-mask:url('octopus-mark.svg?v=4') center/contain no-repeat;mask:url('octopus-mark.svg?v=4') center/contain no-repeat;transition:transform .35s ease}
.brand:hover .brand-mark{transform:rotate(-8deg)}
.site-nav{display:flex;align-items:center;gap:30px}
.site-nav a{color:var(--body);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:600}
.site-nav a:hover,.site-nav a.active{color:var(--ink)}
.site-nav a.active{box-shadow:inset 0 -2px 0 var(--accent)}
.nav-cta{background:var(--navy);color:#fff!important;padding:11px 22px;border-radius:2px;letter-spacing:.16em;transition:background .16s}
.nav-cta:hover{background:var(--accent)}
.navtoggle,.navbtn{display:none}

/* buttons */
.btn{display:inline-block;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:600;padding:15px 28px;border:1px solid transparent;border-radius:2px;cursor:pointer;transition:.16s;font-family:var(--sans)}
.btn-amber{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-amber:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-ghost{border-color:var(--ink);color:var(--ink);background:transparent}
.btn-ghost:hover{background:var(--ink);color:#fff}

/* hero */
.hero{position:relative;min-height:84vh;display:flex;align-items:center;background:var(--navy);color:#fff;overflow:hidden;border-bottom:1px solid var(--line-soft)}
.hero-img{position:absolute;inset:0;background:url('hero.jpg') center/cover no-repeat;animation:heroDrift 26s ease-in-out infinite alternate}
@keyframes heroDrift{from{transform:scale(1)}to{transform:scale(1.06)}}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(7,22,38,.88),rgba(7,22,38,.55) 42%,rgba(7,22,38,.14) 72%,rgba(7,22,38,0))}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--wrap);margin:0 auto;padding:96px 32px}
.hero-copy{max-width:680px}
.hero .eyebrow{color:#fff}
.hero .eyebrow::before{background:var(--accent)}
.hero h1{color:#fff;margin:.1em 0 .32em;max-width:16ch;font-size:clamp(2.6rem,5.4vw,4.6rem)}
.hero h1 em{font-style:italic;color:#ff9ccb;background:none;padding:0}
.hero-sub{color:#d8e6ee;font-size:1.28rem;line-height:1.55;max-width:56ch;margin:0 0 1.7em}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin:0 0 1.4em}
.hero .btn-amber{background:var(--accent);border-color:var(--accent);color:#0a1f33}
.hero .btn-amber:hover{background:#fff;color:var(--navy);border-color:#fff}
.hero .btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.hero .btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.hero-note{display:inline-block;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:#bcd8da;font-weight:600}

/* sections */
section{padding:var(--sec) 0}
.band{background:var(--bg-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.two-col{display:grid;grid-template-columns:1fr 1.15fr;gap:60px;align-items:start}
.prose p:last-child{margin-bottom:0}
.lede{font-size:1.32rem;color:var(--ink);font-family:var(--serif);line-height:1.4}
.center{text-align:center}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);margin:0 auto;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:0}
.stats .stat{padding:34px 20px;text-align:center;border-right:1px solid var(--line)}
.stats .stat:last-child{border-right:none}
.stat .num{display:block;font-family:var(--serif);font-size:2.7rem;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.stat .lab{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted);margin-top:.7em;display:block}

/* cards */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:44px;border-top:1px solid var(--line)}
.card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);border-top:3px solid var(--accent);margin-top:-1px;padding:30px 26px 38px;transition:background .2s}
.card:hover{background:var(--bg-2)}
.card:nth-child(4n){border-right:none}
.card-no{font-family:var(--serif);font-style:italic;color:var(--navy);font-size:1.15rem;display:block;margin-bottom:1.3em}
.card h3{margin:0 0 .45em;font-size:1.4rem}
.card h3 a{color:var(--ink)}
.card h3 a:hover{color:var(--accent-deep)}
.card p{font-size:.96rem;margin:0}
.card .tag{display:inline-block;margin-top:1em;text-transform:uppercase;letter-spacing:.14em;font-size:.64rem;font-weight:600;color:var(--accent-deep);border:1px solid var(--accent-soft);background:var(--accent-soft);padding:4px 10px;border-radius:2px}

/* quote band */
.quote-band{background:var(--abyss);text-align:center;position:relative;overflow:hidden}
.quote-band::after{content:"";position:absolute;right:-70px;bottom:-90px;width:340px;height:340px;background:rgba(255,255,255,.045);-webkit-mask:url('octopus-mark.svg?v=4') center/contain no-repeat;mask:url('octopus-mark.svg?v=4') center/contain no-repeat;pointer-events:none}
.quote-band blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.7rem,3.6vw,2.8rem);color:#fff;max-width:24ch;margin:0 auto .5em;line-height:1.3;position:relative;z-index:1}
.quote-band cite{font-style:normal;text-transform:uppercase;letter-spacing:.2em;font-size:.74rem;color:var(--accent);position:relative;z-index:1}

/* track record */
.track{list-style:none;margin:44px 0 0;padding:0;border-top:1px solid var(--line)}
.track li{display:grid;grid-template-columns:200px 1fr auto;gap:28px;align-items:baseline;padding:22px 4px;border-bottom:1px solid var(--line);transition:background .2s}
.track li:hover{background:var(--bg-2)}
.track .t-name{font-family:var(--serif);font-size:1.45rem;color:var(--ink);font-weight:600}
.track .t-name a{color:var(--ink)}.track .t-name a:hover{color:var(--accent-deep)}
.track .t-desc{font-size:.98rem;color:var(--body)}
.track .t-fact{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--accent-deep);white-space:nowrap}

/* steps */
.steps{list-style:none;padding:0;margin:0 0 44px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.steps li{padding:30px 26px 10px;border-right:1px solid var(--line)}
.steps li:last-child{border-right:none}
.steps li span{font-family:var(--serif);font-style:italic;color:var(--navy);font-size:1.7rem;display:block;margin-bottom:.4em}
.steps li h3{margin:0 0 .35em;font-size:1.35rem}
.steps li p{font-size:.96rem;margin:0}

/* page hero */
.page-hero{padding:calc(var(--sec)*.85) 0 calc(var(--sec)/2);background:var(--bg-2)}
.page-hero h1{margin:.15em 0 .3em}
.page-hero .lede{max-width:62ch}
.page-hero+section{padding-top:calc(var(--sec)/2)}

/* content layouts */
.content-cols{display:grid;grid-template-columns:1.7fr .9fr;gap:64px;align-items:start}
.narrow{max-width:var(--col)}
.prose-lg h2{font-family:var(--serif);font-weight:600;font-size:1.6rem;line-height:1.18;margin:1.5em 0 .45em;letter-spacing:0}
.prose-lg h2:first-child{margin-top:0}
.prose-lg p{font-size:1.06rem;line-height:1.6;margin:0 0 1.05em}
.pullquote{border:none;border-left:3px solid var(--accent);margin:2em 0;padding:.1em 0 .1em 26px;font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3vw,2rem);color:var(--ink);line-height:1.3}
.pullquote cite{display:block;font-style:normal;text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--muted);margin-top:.7em}
.about-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:2em}

/* faq */
.faq-list{max-width:840px;margin-top:24px}
.faq{border-top:1px solid var(--line)}
.faq:last-child{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;padding:24px 4px;font-family:var(--serif);font-size:1.4rem;color:var(--ink);list-style:none;display:flex;justify-content:space-between;gap:18px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent-deep);font-size:1.5rem;line-height:1}
.faq[open] summary::after{content:"\2013"}
.faq-a{padding:0 4px 24px}
.faq-a p{margin:0}

/* figure bands */
.figure-band{width:100%;height:46vw;max-height:540px;background:var(--bg-3) center/cover no-repeat;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.figure-cut-wrap{padding:14px 32px 0}
.figure-cut{display:block;width:100%;max-width:520px;height:auto;margin:0 auto}

/* platforms grid */
.plat-cards{grid-template-columns:repeat(3,1fr)}
.plat-cards .card-no{font-family:var(--sans);font-style:normal;text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--accent-deep);font-weight:600}
.plat-cards .card:nth-child(4n){border-right:1px solid var(--line)}
.plat-cards .card:nth-child(3n){border-right:none}

/* team */
.member h3{margin:0 0 .15em;font-size:1.7rem}
.member .role{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--accent-deep);font-weight:600;margin:0 0 .9em}
.member p{font-size:1.02rem;margin:0 0 1em}
.member .li{display:inline-flex;align-items:center;gap:7px;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600;color:var(--navy);margin-right:18px}
.member .li svg{width:15px;height:15px;fill:var(--navy)}
.member .li:hover{color:var(--accent-deep)}
.member .li:hover svg{fill:var(--accent-deep)}
.creds{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 1.4em;padding:0;list-style:none}
.creds li{text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;font-weight:600;color:var(--navy);border:1px solid var(--line);padding:6px 12px;border-radius:2px;background:var(--bg-2)}

/* contact */
.contact-form .field{margin-bottom:20px;display:flex;flex-direction:column}
.contact-form label{text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--muted);margin-bottom:8px}
.contact-form input,.contact-form textarea{font-family:var(--sans);font-size:1rem;padding:13px 15px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:2px}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent);border-color:var(--accent)}
.form-note{display:block;margin-top:10px;font-size:.84rem;color:var(--muted)}
.sidebar{display:flex;flex-direction:column;gap:1px;position:sticky;top:96px;background:var(--line);border:1px solid var(--line)}
.sb-card{background:var(--bg);padding:28px}
.sb-card h3{margin:0 0 .8em;font-size:1.2rem}
address{font-style:normal;color:var(--body)}
address a{color:var(--ink)}

/* mini cta */
.mini-cta-in{border:1px solid var(--line);border-top:3px solid var(--accent);padding:54px;text-align:center;background:var(--bg-2)}
.mini-cta-in h2{margin-bottom:.2em}

/* footer */
.site-foot{background:var(--abyss);color:#c2cdd9}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:48px;padding:72px 32px 44px}
.foot-brandrow{font-family:var(--serif);font-size:1.3rem;color:#fff;margin-bottom:18px;letter-spacing:.03em}
.foot-brandrow b{font-weight:600}.foot-brandrow em{color:var(--accent);font-style:italic}
.foot-mark{display:inline-block;vertical-align:-7px;width:30px;height:30px;margin-right:11px;background:var(--accent);-webkit-mask:url('octopus-mark.svg?v=4') center/contain no-repeat;mask:url('octopus-mark.svg?v=4') center/contain no-repeat}
.foot-mission{font-size:.98rem;color:#93a2b3;max-width:46ch}
.foot-social{display:flex;gap:20px;margin-top:18px}
.foot-social a{text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--accent)}
.foot-social a:hover{color:#fff}
.foot-col h3{color:#fff;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;margin:0 0 1.3em;font-weight:600;font-family:var(--sans)}
.foot-links{display:flex;flex-direction:column;gap:12px}
.foot-links a,.foot-col address a{color:#c2cdd9}
.foot-links a:hover,.foot-col address a:hover{color:var(--accent)}
.foot-col address{line-height:1.9}
.foot-net{border-top:1px solid rgba(255,255,255,.12);padding:38px 32px}
.foot-net h3{color:#93a2b3;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;margin:0 0 18px;font-family:var(--sans)}
.net-links{display:flex;flex-wrap:wrap;gap:10px 26px}
.net-links a{text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:#c2cdd9}
.net-links a:hover{color:var(--accent)}
.foot-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;border-top:1px solid rgba(255,255,255,.12);padding:24px 32px;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:#7a8a9b}
.foot-base a{color:var(--accent)}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
.no-js .rv{opacity:1;transform:none}

/* 404 */
.lost{min-height:56vh;display:flex;align-items:center}
.lost .big{font-family:var(--serif);font-style:italic;font-size:clamp(5rem,14vw,10rem);color:var(--line);line-height:1;margin:0}

/* responsive */
@media(max-width:920px){
  .two-col,.content-cols{grid-template-columns:1fr;gap:36px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .card:nth-child(4n){border-right:1px solid var(--line)}
  .card:nth-child(2n){border-right:none!important}
  .plat-cards{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .steps li{border-bottom:1px solid var(--line)}
  .steps li:nth-child(2n){border-right:none}
  .sidebar{position:static}
  .foot-grid{grid-template-columns:1fr 1fr}
  .track li{grid-template-columns:1fr;gap:4px}
  .track .t-fact{white-space:normal}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stats .stat:nth-child(2n){border-right:none}
  .stats .stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
}
@media(max-width:680px){
  .navbtn{display:flex;flex-direction:column;gap:5px;width:30px;cursor:pointer;background:none;border:none;padding:0}
  .navbtn span{height:2px;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .2s ease;transform-origin:center}
  .navtoggle:checked ~ .navbtn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .navtoggle:checked ~ .navbtn span:nth-child(2){opacity:0}
  .navtoggle:checked ~ .navbtn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .site-nav{position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;gap:0;padding:8px 0;transform:translateY(-130%);transition:.25s;border-bottom:1px solid var(--line);align-items:stretch}
  .navtoggle:checked ~ .site-nav{transform:translateY(0)}
  .site-nav a{padding:16px 32px;width:100%}
  .nav-cta{margin:12px 32px;text-align:center}
  .cards,.plat-cards{grid-template-columns:1fr}
  .card{border-right:none!important}
  .steps{grid-template-columns:1fr}
  .steps li{border-right:none}
  .foot-grid{grid-template-columns:1fr}
  body{font-size:18px}
  .hero{min-height:auto}
  .hero-inner{padding:90px 22px 64px}
  .brand-mark{width:26px;height:26px}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .hero-img{animation:none}
  .rv{opacity:1;transform:none;transition:none}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* small octopus glyph accents */
.mini-mark{display:inline-block;width:18px;height:18px;vertical-align:-3px;color:var(--accent)}
.marker .mini-mark{flex:none;color:var(--navy);width:20px;height:20px;vertical-align:baseline}
.mini-cta-in .mini-mark{display:block;margin:0 auto 16px;width:30px;height:30px;color:var(--navy)}
.quote-band cite .mini-mark{color:var(--accent);width:16px;height:16px;margin-right:9px;vertical-align:-2px}
.sb-card h3 .mini-mark{width:15px;height:15px;color:var(--accent);margin-right:8px;vertical-align:-2px}
.lost .mini-mark{width:54px;height:54px;color:var(--accent);display:block;margin-bottom:18px}
